netra-sdk 1.0.5 → 1.1.0-beta
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{chunk-OY22X7BX.js → chunk-WMQRYJGR.js} +3 -3
- package/dist/{chunk-OY22X7BX.js.map → chunk-WMQRYJGR.js.map} +1 -1
- package/dist/{dist-7XG2FAEZ.js → dist-GIPRCO2C.js} +233 -3804
- package/dist/dist-GIPRCO2C.js.map +1 -0
- package/dist/index.cjs +5426 -7646
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +781 -671
- package/dist/index.d.ts +781 -671
- package/dist/index.js +4237 -2770
- package/dist/index.js.map +1 -1
- package/package.json +15 -2
- package/dist/dist-7XG2FAEZ.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../node_modules/@traceloop/ai-semantic-conventions/src/SemanticAttributes.ts","../node_modules/@traceloop/ai-semantic-conventions/src/index.ts","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/load/map_keys.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/load/validation.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/load/serializable.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/utils/env.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/callbacks/base.cjs","../node_modules/ansi-styles/index.js","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/experimental/otel/constants.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/singletons/fetch.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/utils/project.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/utils/warn.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/utils/_uuid.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/uuid.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/index.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/utils/env.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/singletons/otel.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/experimental/otel/translator.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/utils/is-network-error/index.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/utils/p-retry/index.cjs","../node_modules/eventemitter3/index.js","../node_modules/p-finally/index.js","../node_modules/p-timeout/index.js","../node_modules/p-queue/dist/lower-bound.js","../node_modules/p-queue/dist/priority-queue.js","../node_modules/p-queue/dist/index.js","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/utils/async_caller.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/utils/messages.cjs","../node_modules/semver/internal/constants.js","../node_modules/semver/internal/debug.js","../node_modules/semver/internal/re.js","../node_modules/semver/internal/parse-options.js","../node_modules/semver/internal/identifiers.js","../node_modules/semver/classes/semver.js","../node_modules/semver/functions/parse.js","../node_modules/semver/functions/valid.js","../node_modules/semver/functions/clean.js","../node_modules/semver/functions/inc.js","../node_modules/semver/functions/diff.js","../node_modules/semver/functions/major.js","../node_modules/semver/functions/minor.js","../node_modules/semver/functions/patch.js","../node_modules/semver/functions/prerelease.js","../node_modules/semver/functions/compare.js","../node_modules/semver/functions/rcompare.js","../node_modules/semver/functions/compare-loose.js","../node_modules/semver/functions/compare-build.js","../node_modules/semver/functions/sort.js","../node_modules/semver/functions/rsort.js","../node_modules/semver/functions/gt.js","../node_modules/semver/functions/lt.js","../node_modules/semver/functions/eq.js","../node_modules/semver/functions/neq.js","../node_modules/semver/functions/gte.js","../node_modules/semver/functions/lte.js","../node_modules/semver/functions/cmp.js","../node_modules/semver/functions/coerce.js","../node_modules/semver/internal/lrucache.js","../node_modules/semver/classes/range.js","../node_modules/semver/classes/comparator.js","../node_modules/semver/functions/satisfies.js","../node_modules/semver/ranges/to-comparators.js","../node_modules/semver/ranges/max-satisfying.js","../node_modules/semver/ranges/min-satisfying.js","../node_modules/semver/ranges/min-version.js","../node_modules/semver/ranges/valid.js","../node_modules/semver/ranges/outside.js","../node_modules/semver/ranges/gtr.js","../node_modules/semver/ranges/ltr.js","../node_modules/semver/ranges/intersects.js","../node_modules/semver/ranges/simplify.js","../node_modules/semver/ranges/subset.js","../node_modules/semver/index.js","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/utils/prompts.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/utils/error.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/utils/fast-safe-stringify/index.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/client.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/env.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/singletons/constants.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/utils/context_vars.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/run_trees.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/run_trees.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/tracers/base.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/tracers/console.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/errors/index.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/tools/utils.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/utils/json.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/messages/content_blocks.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/messages/base.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/messages/tool.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/messages/ai.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/messages/chat.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/messages/function.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/messages/human.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/messages/modifier.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/messages/system.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/messages/utils.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/index.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/dist/singletons/traceable.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/langsmith/singletons/traceable.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/singletons/tracer.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/tracers/tracer_langchain.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/singletons/async_local_storage/globals.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/singletons/callbacks.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/callbacks/promises.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/utils/callbacks.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/singletons/async_local_storage/context.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/callbacks/manager.cjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/callbacks/manager.cjs","../node_modules/@traceloop/instrumentation-langchain/dist/index.mjs","../node_modules/tslib/tslib.es6.mjs","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/callbacks/base.js","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/load/map_keys.js","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/load/validation.js","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/load/serializable.js","../node_modules/@traceloop/instrumentation-langchain/node_modules/@langchain/core/dist/utils/env.js","../node_modules/@opentelemetry/semantic-conventions/src/experimental_attributes.ts"],"names":["exports","LLMRequestTypeValues","TraceloopSpanKindValues","keyToJson","mapKeys","needsEscaping","escapeObject","escapeIfNeeded","isSerializableLike","get_lc_unique_name","shallowCopy","replaceSecrets","Serializable","getEnvironmentVariable","isDeno","o","BaseCallbackHandlerMethodsClass","BaseCallbackHandler","fetch","version","require_uuid","require_env","context","require_dist","require_constants","require_valid","require_semver","body","batch","attachments","datasetId_","datasetName_","response","examples","value","require_run_trees","require_base","elapsed","obj","toolCalls","require_utils","require_traceable","require_callbacks","err","require_manager","snakeCase"],"mappings":"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","file":"dist-GIPRCO2C.js","sourcesContent":["/*\n * Copyright Traceloop\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport const SpanAttributes = {\n // Attributes not yet in @opentelemetry/semantic-conventions\n GEN_AI_USAGE_CACHE_CREATION_INPUT_TOKENS:\n \"gen_ai.usage.cache_creation_input_tokens\",\n GEN_AI_USAGE_CACHE_READ_INPUT_TOKENS: \"gen_ai.usage.cache_read_input_tokens\",\n GEN_AI_USAGE_REASONING_TOKENS: \"gen_ai.usage.reasoning_tokens\",\n\n // LLM\n LLM_REQUEST_TYPE: \"llm.request.type\",\n LLM_USAGE_TOTAL_TOKENS: \"llm.usage.total_tokens\",\n LLM_TOP_K: \"llm.top_k\",\n LLM_FREQUENCY_PENALTY: \"llm.frequency_penalty\",\n LLM_PRESENCE_PENALTY: \"llm.presence_penalty\",\n LLM_CHAT_STOP_SEQUENCES: \"llm.chat.stop_sequences\",\n LLM_REQUEST_FUNCTIONS: \"llm.request.functions\",\n\n // Vector DB\n VECTOR_DB_VENDOR: \"db.system\",\n VECTOR_DB_QUERY_TOP_K: \"db.vector.query.top_k\",\n VECTOR_DB_TABLE_NAME: \"db.vector.table_name\",\n VECTOR_DB_ADD_COUNT: \"db.vector.add.count\",\n VECTOR_DB_DELETE_SELECTOR: \"db.vector.delete.selector\",\n VECTOR_DB_DELETE_COUNT: \"db.vector.delete.count\",\n VECTOR_DB_GET_SELECTOR: \"db.vector.get.selector\",\n VECTOR_DB_GET_COUNT: \"db.vector.get.count\",\n VECTOR_DB_GET_INCLUDE_METADATA: \"db.vector.get.include_metadata\",\n VECTOR_DB_GET_INCLUDE_VALUES: \"db.vector.get.include_values\",\n\n // LLM Workflows\n TRACELOOP_SPAN_KIND: \"traceloop.span.kind\",\n TRACELOOP_WORKFLOW_NAME: \"traceloop.workflow.name\",\n TRACELOOP_ENTITY_NAME: \"traceloop.entity.name\",\n TRACELOOP_ENTITY_PATH: \"traceloop.entity.path\",\n TRACELOOP_ENTITY_VERSION: \"traceloop.entity.version\",\n TRACELOOP_ASSOCIATION_PROPERTIES: \"traceloop.association.properties\",\n TRACELOOP_ENTITY_INPUT: \"traceloop.entity.input\",\n TRACELOOP_ENTITY_OUTPUT: \"traceloop.entity.output\",\n\n // MCP (Model Context Protocol)\n MCP_RESPONSE_VALUE: \"mcp.response.value\",\n MCP_REQUEST_ID: \"mcp.request.id\",\n};\n\nexport const Events = {\n DB_QUERY_EMBEDDINGS: \"db.query.embeddings\",\n DB_QUERY_RESULT: \"db.query.result\",\n};\n\nexport const EventAttributes = {\n // Query Embeddings\n DB_QUERY_EMBEDDINGS_VECTOR: \"db.query.embeddings.vector\",\n\n // Query Result (canonical format)\n DB_QUERY_RESULT_ID: \"db.query.result.id\",\n DB_QUERY_RESULT_SCORE: \"db.query.result.score\",\n DB_QUERY_RESULT_DISTANCE: \"db.query.result.distance\",\n DB_QUERY_RESULT_METADATA: \"db.query.result.metadata\",\n DB_QUERY_RESULT_VECTOR: \"db.query.result.vector\",\n DB_QUERY_RESULT_DOCUMENT: \"db.query.result.document\",\n\n // DEPRECATED: Vector DB Query Request\n VECTOR_DB_QUERY_TOP_K: \"db.vector.query.top_k\",\n VECTOR_DB_QUERY_INCLUDE_VALUES: \"db.vector.query.include_values\",\n VECTOR_DB_QUERY_INCLUDE_METADATA: \"db.vector.query.include_metadata\",\n VECTOR_DB_QUERY_ID: \"db.vector.query.id\",\n VECTOR_DB_QUERY_EMBEDDINGS_VECTOR: \"db.vector.query.embeddings.vector\",\n VECTOR_DB_QUERY_METADATA_FILTER: \"db.vector.query.metadata_filter\",\n\n // DEPRECATED: Vector DB Query Response\n VECTOR_DB_QUERY_RESULT_NAMESPACE: \"db.vector.query.result.namespace\",\n VECTOR_DB_QUERY_RESULT_READ_UNITS_CONSUMED:\n \"db.vector.query.result.read_units\",\n VECTOR_DB_QUERY_RESULT_MATCHES_LENGTH:\n \"db.vector.query.result.matches_length\",\n\n // DEPRECATED: Vector DB Query Response of each result\n VECTOR_DB_QUERY_RESULT_SCORE: \"db.vector.query.result.{i}.score\",\n VECTOR_DB_QUERY_RESULT_ID: \"db.vector.query.result.{i}.id\",\n VECTOR_DB_QUERY_RESULT_VALUES: \"db.vector.query.result.{i}.values\",\n VECTOR_DB_QUERY_RESULT_SPARSE_INDICES:\n \"db.vector.query.result.{i}.sparse.indices\",\n VECTOR_DB_QUERY_RESULT_SPARSE_VALUES:\n \"db.vector.query.result.{i}.sparse.values\",\n VECTOR_DB_QUERY_RESULT_METADATA: \"db.vector.query.result.{i}.metadata\",\n};\n\nexport enum LLMRequestTypeValues {\n COMPLETION = \"completion\",\n CHAT = \"chat\",\n RERANK = \"rerank\",\n UNKNOWN = \"unknown\",\n}\n\nexport enum TraceloopSpanKindValues {\n WORKFLOW = \"workflow\",\n TASK = \"task\",\n AGENT = \"agent\",\n TOOL = \"tool\",\n SESSION = \"session\",\n UNKNOWN = \"unknown\",\n}\n","/*\n * Copyright Traceloop\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { createContextKey } from \"@opentelemetry/api\";\n\nexport * from \"./SemanticAttributes\";\n\nexport const CONTEXT_KEY_ALLOW_TRACE_CONTENT = createContextKey(\n \"allow_trace_content\",\n);\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.keyToJson = keyToJson;\nexports.keyFromJson = keyFromJson;\nexports.mapKeys = mapKeys;\nconst decamelize_1 = __importDefault(require(\"decamelize\"));\nconst camelcase_1 = __importDefault(require(\"camelcase\"));\nfunction keyToJson(key, map) {\n return map?.[key] || (0, decamelize_1.default)(key);\n}\nfunction keyFromJson(key, map) {\n return map?.[key] || (0, camelcase_1.default)(key);\n}\nfunction mapKeys(fields, mapper, map) {\n const mapped = {};\n for (const key in fields) {\n if (Object.hasOwn(fields, key)) {\n mapped[mapper(key, map)] = fields[key];\n }\n }\n return mapped;\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.LC_ESCAPED_KEY = void 0;\nexports.needsEscaping = needsEscaping;\nexports.escapeObject = escapeObject;\nexports.isEscapedObject = isEscapedObject;\nexports.serializeValue = serializeValue;\nexports.serializeLcObject = serializeLcObject;\nexports.escapeIfNeeded = escapeIfNeeded;\nexports.unescapeValue = unescapeValue;\n/**\n * Sentinel key used to mark escaped user objects during serialization.\n *\n * When a plain object contains 'lc' key (which could be confused with LC objects),\n * we wrap it as `{\"__lc_escaped__\": {...original...}}`.\n */\nexports.LC_ESCAPED_KEY = \"__lc_escaped__\";\n/**\n * Check if an object needs escaping to prevent confusion with LC objects.\n *\n * An object needs escaping if:\n * 1. It has an `'lc'` key (could be confused with LC serialization format)\n * 2. It has only the escape key (would be mistaken for an escaped object)\n */\nfunction needsEscaping(obj) {\n return (\"lc\" in obj || (Object.keys(obj).length === 1 && exports.LC_ESCAPED_KEY in obj));\n}\n/**\n * Wrap an object in the escape marker.\n *\n * @example\n * ```typescript\n * {\"key\": \"value\"} // becomes {\"__lc_escaped__\": {\"key\": \"value\"}}\n * ```\n */\nfunction escapeObject(obj) {\n return { [exports.LC_ESCAPED_KEY]: obj };\n}\n/**\n * Check if an object is an escaped user object.\n *\n * @example\n * ```typescript\n * {\"__lc_escaped__\": {...}} // is an escaped object\n * ```\n */\nfunction isEscapedObject(obj) {\n return Object.keys(obj).length === 1 && exports.LC_ESCAPED_KEY in obj;\n}\n/**\n * Check if an object looks like a Serializable instance (duck typing).\n */\nfunction isSerializableLike(obj) {\n return (obj !== null &&\n typeof obj === \"object\" &&\n \"lc_serializable\" in obj &&\n typeof obj.toJSON === \"function\");\n}\n/**\n * Create a \"not_implemented\" serialization result for objects that cannot be serialized.\n */\nfunction createNotImplemented(obj) {\n let id;\n if (obj !== null && typeof obj === \"object\") {\n if (\"lc_id\" in obj && Array.isArray(obj.lc_id)) {\n id = obj.lc_id;\n }\n else {\n id = [obj.constructor?.name ?? \"Object\"];\n }\n }\n else {\n id = [typeof obj];\n }\n return {\n lc: 1,\n type: \"not_implemented\",\n id,\n };\n}\n/**\n * Serialize a value with escaping of user objects.\n *\n * Called recursively on kwarg values to escape any plain objects that could be\n * confused with LC objects.\n *\n * @param obj - The value to serialize.\n * @returns The serialized value with user objects escaped as needed.\n */\nfunction serializeValue(obj) {\n if (isSerializableLike(obj)) {\n // This is an LC object - serialize it properly (not escaped)\n return serializeLcObject(obj);\n }\n if (obj !== null && typeof obj === \"object\" && !Array.isArray(obj)) {\n const record = obj;\n // Check if object needs escaping BEFORE recursing into values.\n // If it needs escaping, wrap it as-is - the contents are user data that\n // will be returned as-is during deserialization (no instantiation).\n // This prevents re-escaping of already-escaped nested content.\n if (needsEscaping(record)) {\n return escapeObject(record);\n }\n // Safe object (no 'lc' key) - recurse into values\n const result = {};\n for (const [key, value] of Object.entries(record)) {\n result[key] = serializeValue(value);\n }\n return result;\n }\n if (Array.isArray(obj)) {\n return obj.map((item) => serializeValue(item));\n }\n if (typeof obj === \"string\" ||\n typeof obj === \"number\" ||\n typeof obj === \"boolean\" ||\n obj === null) {\n return obj;\n }\n // Non-JSON-serializable object (Date, custom objects, etc.)\n return createNotImplemented(obj);\n}\n/**\n * Serialize a `Serializable` object with escaping of user data in kwargs.\n *\n * @param obj - The `Serializable` object to serialize.\n * @returns The serialized object with user data in kwargs escaped as needed.\n *\n * @remarks\n * Kwargs values are processed with `serializeValue` to escape user data (like\n * metadata) that contains `'lc'` keys. Secret fields (from `lc_secrets`) are\n * skipped because `toJSON()` replaces their values with secret markers.\n */\nfunction serializeLcObject(obj) {\n // Secret fields are handled by toJSON() - it replaces values with secret markers\n const secretFields = new Set(Object.keys(obj.lc_secrets ?? {}));\n const serialized = { ...obj.toJSON() };\n // Process kwargs to escape user data that could be confused with LC objects\n // Skip secret fields - toJSON() already converted them to secret markers\n if (serialized.type === \"constructor\" && serialized.kwargs) {\n const newKwargs = {};\n for (const [key, value] of Object.entries(serialized.kwargs)) {\n if (secretFields.has(key)) {\n newKwargs[key] = value;\n }\n else {\n newKwargs[key] = serializeValue(value);\n }\n }\n serialized.kwargs = newKwargs;\n }\n return serialized;\n}\n/**\n * Escape a value if it needs escaping (contains `lc` key).\n *\n * This is a simpler version of `serializeValue` that doesn't handle Serializable\n * objects - it's meant to be called on kwargs values that have already been\n * processed by `toJSON()`.\n *\n * @param value - The value to potentially escape.\n * @returns The value with any `lc`-containing objects wrapped in escape markers.\n */\nfunction escapeIfNeeded(value) {\n if (value !== null && typeof value === \"object\" && !Array.isArray(value)) {\n // Preserve Serializable objects - they have their own toJSON() that will be\n // called by JSON.stringify. We don't want to convert them to plain objects.\n if (isSerializableLike(value)) {\n return value;\n }\n const record = value;\n // Check if object needs escaping BEFORE recursing into values.\n // If it needs escaping, wrap it as-is - the contents are user data that\n // will be returned as-is during deserialization (no instantiation).\n if (needsEscaping(record)) {\n return escapeObject(record);\n }\n // Safe object (no 'lc' key) - recurse into values\n const result = {};\n for (const [key, val] of Object.entries(record)) {\n result[key] = escapeIfNeeded(val);\n }\n return result;\n }\n if (Array.isArray(value)) {\n return value.map((item) => escapeIfNeeded(item));\n }\n return value;\n}\n/**\n * Unescape a value, processing escape markers in object values and arrays.\n *\n * When an escaped object is encountered (`{\"__lc_escaped__\": ...}`), it's\n * unwrapped and the contents are returned AS-IS (no further processing).\n * The contents represent user data that should not be modified.\n *\n * For regular objects and arrays, we recurse to find any nested escape markers.\n *\n * @param obj - The value to unescape.\n * @returns The unescaped value.\n */\nfunction unescapeValue(obj) {\n if (obj !== null && typeof obj === \"object\" && !Array.isArray(obj)) {\n const record = obj;\n if (isEscapedObject(record)) {\n // Unwrap and return the user data as-is (no further unescaping).\n // The contents are user data that may contain more escape keys,\n // but those are part of the user's actual data.\n return record[exports.LC_ESCAPED_KEY];\n }\n // Regular object - recurse into values to find nested escape markers\n const result = {};\n for (const [key, value] of Object.entries(record)) {\n result[key] = unescapeValue(value);\n }\n return result;\n }\n if (Array.isArray(obj)) {\n return obj.map((item) => unescapeValue(item));\n }\n return obj;\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Serializable = void 0;\nexports.get_lc_unique_name = get_lc_unique_name;\nconst map_keys_js_1 = require(\"./map_keys.cjs\");\nconst validation_js_1 = require(\"./validation.cjs\");\nfunction shallowCopy(obj) {\n return Array.isArray(obj) ? [...obj] : { ...obj };\n}\nfunction replaceSecrets(root, secretsMap) {\n const result = shallowCopy(root);\n for (const [path, secretId] of Object.entries(secretsMap)) {\n const [last, ...partsReverse] = path.split(\".\").reverse();\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let current = result;\n for (const part of partsReverse.reverse()) {\n if (current[part] === undefined) {\n break;\n }\n current[part] = shallowCopy(current[part]);\n current = current[part];\n }\n if (current[last] !== undefined) {\n current[last] = {\n lc: 1,\n type: \"secret\",\n id: [secretId],\n };\n }\n }\n return result;\n}\n/**\n * Get a unique name for the module, rather than parent class implementations.\n * Should not be subclassed, subclass lc_name above instead.\n */\nfunction get_lc_unique_name(\n// eslint-disable-next-line @typescript-eslint/no-use-before-define\nserializableClass) {\n // \"super\" here would refer to the parent class of Serializable,\n // when we want the parent class of the module actually calling this method.\n const parentClass = Object.getPrototypeOf(serializableClass);\n const lcNameIsSubclassed = typeof serializableClass.lc_name === \"function\" &&\n (typeof parentClass.lc_name !== \"function\" ||\n serializableClass.lc_name() !== parentClass.lc_name());\n if (lcNameIsSubclassed) {\n return serializableClass.lc_name();\n }\n else {\n return serializableClass.name;\n }\n}\nclass Serializable {\n /**\n * The name of the serializable. Override to provide an alias or\n * to preserve the serialized module name in minified environments.\n *\n * Implemented as a static method to support loading logic.\n */\n static lc_name() {\n return this.name;\n }\n /**\n * The final serialized identifier for the module.\n */\n get lc_id() {\n return [\n ...this.lc_namespace,\n get_lc_unique_name(this.constructor),\n ];\n }\n /**\n * A map of secrets, which will be omitted from serialization.\n * Keys are paths to the secret in constructor args, e.g. \"foo.bar.baz\".\n * Values are the secret ids, which will be used when deserializing.\n */\n get lc_secrets() {\n return undefined;\n }\n /**\n * A map of additional attributes to merge with constructor args.\n * Keys are the attribute names, e.g. \"foo\".\n * Values are the attribute values, which will be serialized.\n * These attributes need to be accepted by the constructor as arguments.\n */\n get lc_attributes() {\n return undefined;\n }\n /**\n * A map of aliases for constructor args.\n * Keys are the attribute names, e.g. \"foo\".\n * Values are the alias that will replace the key in serialization.\n * This is used to eg. make argument names match Python.\n */\n get lc_aliases() {\n return undefined;\n }\n /**\n * A manual list of keys that should be serialized.\n * If not overridden, all fields passed into the constructor will be serialized.\n */\n get lc_serializable_keys() {\n return undefined;\n }\n constructor(kwargs, ..._args) {\n Object.defineProperty(this, \"lc_serializable\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"lc_kwargs\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n if (this.lc_serializable_keys !== undefined) {\n this.lc_kwargs = Object.fromEntries(Object.entries(kwargs || {}).filter(([key]) => this.lc_serializable_keys?.includes(key)));\n }\n else {\n this.lc_kwargs = kwargs ?? {};\n }\n }\n toJSON() {\n if (!this.lc_serializable) {\n return this.toJSONNotImplemented();\n }\n if (\n // eslint-disable-next-line no-instanceof/no-instanceof\n this.lc_kwargs instanceof Serializable ||\n typeof this.lc_kwargs !== \"object\" ||\n Array.isArray(this.lc_kwargs)) {\n // We do not support serialization of classes with arg not a POJO\n // I'm aware the check above isn't as strict as it could be\n return this.toJSONNotImplemented();\n }\n const aliases = {};\n const secrets = {};\n const kwargs = Object.keys(this.lc_kwargs).reduce((acc, key) => {\n acc[key] = key in this ? this[key] : this.lc_kwargs[key];\n return acc;\n }, {});\n // get secrets, attributes and aliases from all superclasses\n for (\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let current = Object.getPrototypeOf(this); current; current = Object.getPrototypeOf(current)) {\n Object.assign(aliases, Reflect.get(current, \"lc_aliases\", this));\n Object.assign(secrets, Reflect.get(current, \"lc_secrets\", this));\n Object.assign(kwargs, Reflect.get(current, \"lc_attributes\", this));\n }\n // include all secrets used, even if not in kwargs,\n // will be replaced with sentinel value in replaceSecrets\n Object.keys(secrets).forEach((keyPath) => {\n // eslint-disable-next-line @typescript-eslint/no-this-alias, @typescript-eslint/no-explicit-any\n let read = this;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let write = kwargs;\n const [last, ...partsReverse] = keyPath.split(\".\").reverse();\n for (const key of partsReverse.reverse()) {\n if (!(key in read) || read[key] === undefined)\n return;\n if (!(key in write) || write[key] === undefined) {\n if (typeof read[key] === \"object\" && read[key] != null) {\n write[key] = {};\n }\n else if (Array.isArray(read[key])) {\n write[key] = [];\n }\n }\n read = read[key];\n write = write[key];\n }\n if (last in read && read[last] !== undefined) {\n write[last] = write[last] || read[last];\n }\n });\n const escapedKwargs = {};\n for (const [key, value] of Object.entries(kwargs)) {\n escapedKwargs[key] = (0, validation_js_1.escapeIfNeeded)(value);\n }\n // Now add secret markers - these are added AFTER escaping so they won't be escaped\n const kwargsWithSecrets = Object.keys(secrets).length\n ? replaceSecrets(escapedKwargs, secrets)\n : escapedKwargs;\n // Finally transform keys to JSON format\n const processedKwargs = (0, map_keys_js_1.mapKeys)(kwargsWithSecrets, map_keys_js_1.keyToJson, aliases);\n return {\n lc: 1,\n type: \"constructor\",\n id: this.lc_id,\n kwargs: processedKwargs,\n };\n }\n toJSONNotImplemented() {\n return {\n lc: 1,\n type: \"not_implemented\",\n id: this.lc_id,\n };\n }\n}\nexports.Serializable = Serializable;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getEnv = exports.isNode = exports.isDeno = exports.isJsDom = exports.isWebWorker = exports.isBrowser = void 0;\nexports.getRuntimeEnvironment = getRuntimeEnvironment;\nexports.getRuntimeEnvironmentSync = getRuntimeEnvironmentSync;\nexports.getEnvironmentVariable = getEnvironmentVariable;\nconst isBrowser = () => typeof window !== \"undefined\" && typeof window.document !== \"undefined\";\nexports.isBrowser = isBrowser;\nconst isWebWorker = () => typeof globalThis === \"object\" &&\n globalThis.constructor &&\n globalThis.constructor.name === \"DedicatedWorkerGlobalScope\";\nexports.isWebWorker = isWebWorker;\nconst isJsDom = () => (typeof window !== \"undefined\" && window.name === \"nodejs\") ||\n (typeof navigator !== \"undefined\" && navigator.userAgent.includes(\"jsdom\"));\nexports.isJsDom = isJsDom;\n// Supabase Edge Function provides a `Deno` global object\n// without `version` property\nconst isDeno = () => typeof Deno !== \"undefined\";\nexports.isDeno = isDeno;\n// Mark not-as-node if in Supabase Edge Function\nconst isNode = () => typeof process !== \"undefined\" &&\n typeof process.versions !== \"undefined\" &&\n typeof process.versions.node !== \"undefined\" &&\n !(0, exports.isDeno)();\nexports.isNode = isNode;\nconst getEnv = () => {\n let env;\n if ((0, exports.isBrowser)()) {\n env = \"browser\";\n }\n else if ((0, exports.isNode)()) {\n env = \"node\";\n }\n else if ((0, exports.isWebWorker)()) {\n env = \"webworker\";\n }\n else if ((0, exports.isJsDom)()) {\n env = \"jsdom\";\n }\n else if ((0, exports.isDeno)()) {\n env = \"deno\";\n }\n else {\n env = \"other\";\n }\n return env;\n};\nexports.getEnv = getEnv;\nlet runtimeEnvironment;\n/**\n * @deprecated Use getRuntimeEnvironmentSync instead\n */\nasync function getRuntimeEnvironment() {\n return getRuntimeEnvironmentSync();\n}\nfunction getRuntimeEnvironmentSync() {\n if (runtimeEnvironment === undefined) {\n const env = (0, exports.getEnv)();\n runtimeEnvironment = {\n library: \"langchain-js\",\n runtime: env,\n };\n }\n return runtimeEnvironment;\n}\nfunction getEnvironmentVariable(name) {\n // Certain Deno setups will throw an error if you try to access environment variables\n // https://github.com/langchain-ai/langchainjs/issues/1412\n try {\n if (typeof process !== \"undefined\") {\n // eslint-disable-next-line no-process-env\n return process.env?.[name];\n }\n else if ((0, exports.isDeno)()) {\n return Deno?.env.get(name);\n }\n else {\n return undefined;\n }\n }\n catch (e) {\n return undefined;\n }\n}\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || (function () {\n var ownKeys = function(o) {\n ownKeys = Object.getOwnPropertyNames || function (o) {\n var ar = [];\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\n return ar;\n };\n return ownKeys(o);\n };\n return function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\n __setModuleDefault(result, mod);\n return result;\n };\n})();\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isBaseCallbackHandler = exports.BaseCallbackHandler = void 0;\nexports.callbackHandlerPrefersStreaming = callbackHandlerPrefersStreaming;\nconst uuid = __importStar(require(\"uuid\"));\nconst serializable_js_1 = require(\"../load/serializable.cjs\");\nconst env_js_1 = require(\"../utils/env.cjs\");\n/**\n * Abstract class that provides a set of optional methods that can be\n * overridden in derived classes to handle various events during the\n * execution of a LangChain application.\n */\nclass BaseCallbackHandlerMethodsClass {\n}\nfunction callbackHandlerPrefersStreaming(x) {\n return \"lc_prefer_streaming\" in x && x.lc_prefer_streaming;\n}\n/**\n * Abstract base class for creating callback handlers in the LangChain\n * framework. It provides a set of optional methods that can be overridden\n * in derived classes to handle various events during the execution of a\n * LangChain application.\n */\nclass BaseCallbackHandler extends BaseCallbackHandlerMethodsClass {\n get lc_namespace() {\n return [\"langchain_core\", \"callbacks\", this.name];\n }\n get lc_secrets() {\n return undefined;\n }\n get lc_attributes() {\n return undefined;\n }\n get lc_aliases() {\n return undefined;\n }\n get lc_serializable_keys() {\n return undefined;\n }\n /**\n * The name of the serializable. Override to provide an alias or\n * to preserve the serialized module name in minified environments.\n *\n * Implemented as a static method to support loading logic.\n */\n static lc_name() {\n return this.name;\n }\n /**\n * The final serialized identifier for the module.\n */\n get lc_id() {\n return [\n ...this.lc_namespace,\n (0, serializable_js_1.get_lc_unique_name)(this.constructor),\n ];\n }\n constructor(input) {\n super();\n Object.defineProperty(this, \"lc_serializable\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"lc_kwargs\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"ignoreLLM\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"ignoreChain\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"ignoreAgent\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"ignoreRetriever\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"ignoreCustomEvent\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"raiseError\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"awaitHandlers\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: (0, env_js_1.getEnvironmentVariable)(\"LANGCHAIN_CALLBACKS_BACKGROUND\") === \"false\"\n });\n this.lc_kwargs = input || {};\n if (input) {\n this.ignoreLLM = input.ignoreLLM ?? this.ignoreLLM;\n this.ignoreChain = input.ignoreChain ?? this.ignoreChain;\n this.ignoreAgent = input.ignoreAgent ?? this.ignoreAgent;\n this.ignoreRetriever = input.ignoreRetriever ?? this.ignoreRetriever;\n this.ignoreCustomEvent =\n input.ignoreCustomEvent ?? this.ignoreCustomEvent;\n this.raiseError = input.raiseError ?? this.raiseError;\n this.awaitHandlers =\n this.raiseError || (input._awaitHandler ?? this.awaitHandlers);\n }\n }\n copy() {\n return new this.constructor(this);\n }\n toJSON() {\n return serializable_js_1.Serializable.prototype.toJSON.call(this);\n }\n toJSONNotImplemented() {\n return serializable_js_1.Serializable.prototype.toJSONNotImplemented.call(this);\n }\n static fromMethods(methods) {\n class Handler extends BaseCallbackHandler {\n constructor() {\n super();\n Object.defineProperty(this, \"name\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: uuid.v4()\n });\n Object.assign(this, methods);\n }\n }\n return new Handler();\n }\n}\nexports.BaseCallbackHandler = BaseCallbackHandler;\nconst isBaseCallbackHandler = (x) => {\n const callbackHandler = x;\n return (callbackHandler !== undefined &&\n typeof callbackHandler.copy === \"function\" &&\n typeof callbackHandler.name === \"string\" &&\n typeof callbackHandler.awaitHandlers === \"boolean\");\n};\nexports.isBaseCallbackHandler = isBaseCallbackHandler;\n","'use strict';\n\nconst ANSI_BACKGROUND_OFFSET = 10;\n\nconst wrapAnsi256 = (offset = 0) => code => `\\u001B[${38 + offset};5;${code}m`;\n\nconst wrapAnsi16m = (offset = 0) => (red, green, blue) => `\\u001B[${38 + offset};2;${red};${green};${blue}m`;\n\nfunction assembleStyles() {\n\tconst codes = new Map();\n\tconst styles = {\n\t\tmodifier: {\n\t\t\treset: [0, 0],\n\t\t\t// 21 isn't widely supported and 22 does the same thing\n\t\t\tbold: [1, 22],\n\t\t\tdim: [2, 22],\n\t\t\titalic: [3, 23],\n\t\t\tunderline: [4, 24],\n\t\t\toverline: [53, 55],\n\t\t\tinverse: [7, 27],\n\t\t\thidden: [8, 28],\n\t\t\tstrikethrough: [9, 29]\n\t\t},\n\t\tcolor: {\n\t\t\tblack: [30, 39],\n\t\t\tred: [31, 39],\n\t\t\tgreen: [32, 39],\n\t\t\tyellow: [33, 39],\n\t\t\tblue: [34, 39],\n\t\t\tmagenta: [35, 39],\n\t\t\tcyan: [36, 39],\n\t\t\twhite: [37, 39],\n\n\t\t\t// Bright color\n\t\t\tblackBright: [90, 39],\n\t\t\tredBright: [91, 39],\n\t\t\tgreenBright: [92, 39],\n\t\t\tyellowBright: [93, 39],\n\t\t\tblueBright: [94, 39],\n\t\t\tmagentaBright: [95, 39],\n\t\t\tcyanBright: [96, 39],\n\t\t\twhiteBright: [97, 39]\n\t\t},\n\t\tbgColor: {\n\t\t\tbgBlack: [40, 49],\n\t\t\tbgRed: [41, 49],\n\t\t\tbgGreen: [42, 49],\n\t\t\tbgYellow: [43, 49],\n\t\t\tbgBlue: [44, 49],\n\t\t\tbgMagenta: [45, 49],\n\t\t\tbgCyan: [46, 49],\n\t\t\tbgWhite: [47, 49],\n\n\t\t\t// Bright color\n\t\t\tbgBlackBright: [100, 49],\n\t\t\tbgRedBright: [101, 49],\n\t\t\tbgGreenBright: [102, 49],\n\t\t\tbgYellowBright: [103, 49],\n\t\t\tbgBlueBright: [104, 49],\n\t\t\tbgMagentaBright: [105, 49],\n\t\t\tbgCyanBright: [106, 49],\n\t\t\tbgWhiteBright: [107, 49]\n\t\t}\n\t};\n\n\t// Alias bright black as gray (and grey)\n\tstyles.color.gray = styles.color.blackBright;\n\tstyles.bgColor.bgGray = styles.bgColor.bgBlackBright;\n\tstyles.color.grey = styles.color.blackBright;\n\tstyles.bgColor.bgGrey = styles.bgColor.bgBlackBright;\n\n\tfor (const [groupName, group] of Object.entries(styles)) {\n\t\tfor (const [styleName, style] of Object.entries(group)) {\n\t\t\tstyles[styleName] = {\n\t\t\t\topen: `\\u001B[${style[0]}m`,\n\t\t\t\tclose: `\\u001B[${style[1]}m`\n\t\t\t};\n\n\t\t\tgroup[styleName] = styles[styleName];\n\n\t\t\tcodes.set(style[0], style[1]);\n\t\t}\n\n\t\tObject.defineProperty(styles, groupName, {\n\t\t\tvalue: group,\n\t\t\tenumerable: false\n\t\t});\n\t}\n\n\tObject.defineProperty(styles, 'codes', {\n\t\tvalue: codes,\n\t\tenumerable: false\n\t});\n\n\tstyles.color.close = '\\u001B[39m';\n\tstyles.bgColor.close = '\\u001B[49m';\n\n\tstyles.color.ansi256 = wrapAnsi256();\n\tstyles.color.ansi16m = wrapAnsi16m();\n\tstyles.bgColor.ansi256 = wrapAnsi256(ANSI_BACKGROUND_OFFSET);\n\tstyles.bgColor.ansi16m = wrapAnsi16m(ANSI_BACKGROUND_OFFSET);\n\n\t// From https://github.com/Qix-/color-convert/blob/3f0e0d4e92e235796ccb17f6e85c72094a651f49/conversions.js\n\tObject.defineProperties(styles, {\n\t\trgbToAnsi256: {\n\t\t\tvalue: (red, green, blue) => {\n\t\t\t\t// We use the extended greyscale palette here, with the exception of\n\t\t\t\t// black and white. normal palette only has 4 greyscale shades.\n\t\t\t\tif (red === green && green === blue) {\n\t\t\t\t\tif (red < 8) {\n\t\t\t\t\t\treturn 16;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (red > 248) {\n\t\t\t\t\t\treturn 231;\n\t\t\t\t\t}\n\n\t\t\t\t\treturn Math.round(((red - 8) / 247) * 24) + 232;\n\t\t\t\t}\n\n\t\t\t\treturn 16 +\n\t\t\t\t\t(36 * Math.round(red / 255 * 5)) +\n\t\t\t\t\t(6 * Math.round(green / 255 * 5)) +\n\t\t\t\t\tMath.round(blue / 255 * 5);\n\t\t\t},\n\t\t\tenumerable: false\n\t\t},\n\t\thexToRgb: {\n\t\t\tvalue: hex => {\n\t\t\t\tconst matches = /(?<colorString>[a-f\\d]{6}|[a-f\\d]{3})/i.exec(hex.toString(16));\n\t\t\t\tif (!matches) {\n\t\t\t\t\treturn [0, 0, 0];\n\t\t\t\t}\n\n\t\t\t\tlet {colorString} = matches.groups;\n\n\t\t\t\tif (colorString.length === 3) {\n\t\t\t\t\tcolorString = colorString.split('').map(character => character + character).join('');\n\t\t\t\t}\n\n\t\t\t\tconst integer = Number.parseInt(colorString, 16);\n\n\t\t\t\treturn [\n\t\t\t\t\t(integer >> 16) & 0xFF,\n\t\t\t\t\t(integer >> 8) & 0xFF,\n\t\t\t\t\tinteger & 0xFF\n\t\t\t\t];\n\t\t\t},\n\t\t\tenumerable: false\n\t\t},\n\t\thexToAnsi256: {\n\t\t\tvalue: hex => styles.rgbToAnsi256(...styles.hexToRgb(hex)),\n\t\t\tenumerable: false\n\t\t}\n\t});\n\n\treturn styles;\n}\n\n// Make the export immutable\nObject.defineProperty(module, 'exports', {\n\tenumerable: true,\n\tget: assembleStyles\n});\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.AI_SDK_TOOL_OPERATIONS = exports.AI_SDK_LLM_OPERATIONS = exports.GEN_AI_CHOICE = exports.GEN_AI_ASSISTANT_MESSAGE = exports.GEN_AI_USER_MESSAGE = exports.GEN_AI_SYSTEM_MESSAGE = exports.LANGSMITH_TRACEABLE_PARENT_OTEL_SPAN_ID = exports.LANGSMITH_IS_ROOT = exports.LANGSMITH_TRACEABLE = exports.LANGSMITH_REFERENCE_EXAMPLE_ID = exports.LANGSMITH_USAGE_METADATA = exports.LANGSMITH_PARENT_RUN_ID = exports.LANGSMITH_DOTTED_ORDER = exports.LANGSMITH_TRACE_ID = exports.LANGSMITH_RUN_ID = exports.LANGSMITH_REQUEST_HEADERS = exports.LANGSMITH_REQUEST_STREAMING = exports.LANGSMITH_RUNTIME = exports.LANGSMITH_TAGS = exports.LANGSMITH_METADATA = exports.LANGSMITH_NAME = exports.LANGSMITH_RUN_TYPE = exports.LANGSMITH_SESSION_NAME = exports.LANGSMITH_SESSION_ID = exports.GEN_AI_USAGE_OUTPUT_TOKEN_DETAILS = exports.GEN_AI_USAGE_INPUT_TOKEN_DETAILS = exports.GEN_AI_RESPONSE_SYSTEM_FINGERPRINT = exports.GEN_AI_RESPONSE_SERVICE_TIER = exports.GEN_AI_RESPONSE_ID = exports.GEN_AI_SERIALIZED_DOC = exports.GEN_AI_SERIALIZED_SIGNATURE = exports.GEN_AI_SERIALIZED_NAME = exports.GEN_AI_REQUEST_EXTRA_BODY = exports.GEN_AI_REQUEST_EXTRA_QUERY = exports.GENAI_COMPLETION = exports.GENAI_PROMPT = exports.GEN_AI_RESPONSE_FINISH_REASONS = exports.GEN_AI_REQUEST_PRESENCE_PENALTY = exports.GEN_AI_REQUEST_FREQUENCY_PENALTY = exports.GEN_AI_REQUEST_TOP_P = exports.GEN_AI_REQUEST_TEMPERATURE = exports.GEN_AI_REQUEST_MAX_TOKENS = exports.GEN_AI_USAGE_TOTAL_TOKENS = exports.GEN_AI_USAGE_OUTPUT_TOKENS = exports.GEN_AI_USAGE_INPUT_TOKENS = exports.GEN_AI_RESPONSE_MODEL = exports.GEN_AI_REQUEST_MODEL = exports.GEN_AI_SYSTEM = exports.GEN_AI_OPERATION_NAME = void 0;\n// OpenTelemetry GenAI semantic convention attribute names\nexports.GEN_AI_OPERATION_NAME = \"gen_ai.operation.name\";\nexports.GEN_AI_SYSTEM = \"gen_ai.system\";\nexports.GEN_AI_REQUEST_MODEL = \"gen_ai.request.model\";\nexports.GEN_AI_RESPONSE_MODEL = \"gen_ai.response.model\";\nexports.GEN_AI_USAGE_INPUT_TOKENS = \"gen_ai.usage.input_tokens\";\nexports.GEN_AI_USAGE_OUTPUT_TOKENS = \"gen_ai.usage.output_tokens\";\nexports.GEN_AI_USAGE_TOTAL_TOKENS = \"gen_ai.usage.total_tokens\";\nexports.GEN_AI_REQUEST_MAX_TOKENS = \"gen_ai.request.max_tokens\";\nexports.GEN_AI_REQUEST_TEMPERATURE = \"gen_ai.request.temperature\";\nexports.GEN_AI_REQUEST_TOP_P = \"gen_ai.request.top_p\";\nexports.GEN_AI_REQUEST_FREQUENCY_PENALTY = \"gen_ai.request.frequency_penalty\";\nexports.GEN_AI_REQUEST_PRESENCE_PENALTY = \"gen_ai.request.presence_penalty\";\nexports.GEN_AI_RESPONSE_FINISH_REASONS = \"gen_ai.response.finish_reasons\";\nexports.GENAI_PROMPT = \"gen_ai.prompt\";\nexports.GENAI_COMPLETION = \"gen_ai.completion\";\nexports.GEN_AI_REQUEST_EXTRA_QUERY = \"gen_ai.request.extra_query\";\nexports.GEN_AI_REQUEST_EXTRA_BODY = \"gen_ai.request.extra_body\";\nexports.GEN_AI_SERIALIZED_NAME = \"gen_ai.serialized.name\";\nexports.GEN_AI_SERIALIZED_SIGNATURE = \"gen_ai.serialized.signature\";\nexports.GEN_AI_SERIALIZED_DOC = \"gen_ai.serialized.doc\";\nexports.GEN_AI_RESPONSE_ID = \"gen_ai.response.id\";\nexports.GEN_AI_RESPONSE_SERVICE_TIER = \"gen_ai.response.service_tier\";\nexports.GEN_AI_RESPONSE_SYSTEM_FINGERPRINT = \"gen_ai.response.system_fingerprint\";\nexports.GEN_AI_USAGE_INPUT_TOKEN_DETAILS = \"gen_ai.usage.input_token_details\";\nexports.GEN_AI_USAGE_OUTPUT_TOKEN_DETAILS = \"gen_ai.usage.output_token_details\";\n// LangSmith custom attributes\nexports.LANGSMITH_SESSION_ID = \"langsmith.trace.session_id\";\nexports.LANGSMITH_SESSION_NAME = \"langsmith.trace.session_name\";\nexports.LANGSMITH_RUN_TYPE = \"langsmith.span.kind\";\nexports.LANGSMITH_NAME = \"langsmith.trace.name\";\nexports.LANGSMITH_METADATA = \"langsmith.metadata\";\nexports.LANGSMITH_TAGS = \"langsmith.span.tags\";\nexports.LANGSMITH_RUNTIME = \"langsmith.span.runtime\";\nexports.LANGSMITH_REQUEST_STREAMING = \"langsmith.request.streaming\";\nexports.LANGSMITH_REQUEST_HEADERS = \"langsmith.request.headers\";\nexports.LANGSMITH_RUN_ID = \"langsmith.span.id\";\nexports.LANGSMITH_TRACE_ID = \"langsmith.trace.id\";\nexports.LANGSMITH_DOTTED_ORDER = \"langsmith.span.dotted_order\";\nexports.LANGSMITH_PARENT_RUN_ID = \"langsmith.span.parent_id\";\nexports.LANGSMITH_USAGE_METADATA = \"langsmith.usage_metadata\";\nexports.LANGSMITH_REFERENCE_EXAMPLE_ID = \"langsmith.reference_example_id\";\nexports.LANGSMITH_TRACEABLE = \"langsmith.traceable\";\nexports.LANGSMITH_IS_ROOT = \"langsmith.is_root\";\nexports.LANGSMITH_TRACEABLE_PARENT_OTEL_SPAN_ID = \"langsmith.traceable_parent_otel_span_id\";\n// GenAI event names\nexports.GEN_AI_SYSTEM_MESSAGE = \"gen_ai.system.message\";\nexports.GEN_AI_USER_MESSAGE = \"gen_ai.user.message\";\nexports.GEN_AI_ASSISTANT_MESSAGE = \"gen_ai.assistant.message\";\nexports.GEN_AI_CHOICE = \"gen_ai.choice\";\nexports.AI_SDK_LLM_OPERATIONS = [\n \"ai.generateText.doGenerate\",\n \"ai.streamText.doStream\",\n \"ai.generateObject.doGenerate\",\n \"ai.streamObject.doStream\",\n];\nexports.AI_SDK_TOOL_OPERATIONS = [\"ai.toolCall\"];\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports._getFetchImplementation = exports._globalFetchImplementationIsNodeFetch = exports.clearFetchImplementation = exports.overrideFetchImplementation = void 0;\nconst env_js_1 = require(\"../utils/env.cjs\");\n// Wrap the default fetch call due to issues with illegal invocations\n// in some environments:\n// https://stackoverflow.com/questions/69876859/why-does-bind-fix-failed-to-execute-fetch-on-window-illegal-invocation-err\n// @ts-expect-error Broad typing to support a range of fetch implementations\nconst DEFAULT_FETCH_IMPLEMENTATION = (...args) => fetch(...args);\nconst LANGSMITH_FETCH_IMPLEMENTATION_KEY = Symbol.for(\"ls:fetch_implementation\");\n/**\n * Overrides the fetch implementation used for LangSmith calls.\n * You should use this if you need to use an implementation of fetch\n * other than the default global (e.g. for dealing with proxies).\n * @param fetch The new fetch functino to use.\n */\nconst overrideFetchImplementation = (fetch) => {\n globalThis[LANGSMITH_FETCH_IMPLEMENTATION_KEY] = fetch;\n};\nexports.overrideFetchImplementation = overrideFetchImplementation;\nconst clearFetchImplementation = () => {\n delete globalThis[LANGSMITH_FETCH_IMPLEMENTATION_KEY];\n};\nexports.clearFetchImplementation = clearFetchImplementation;\nconst _globalFetchImplementationIsNodeFetch = () => {\n const fetchImpl = globalThis[LANGSMITH_FETCH_IMPLEMENTATION_KEY];\n if (!fetchImpl)\n return false;\n // Check if the implementation has node-fetch specific properties\n return (typeof fetchImpl === \"function\" &&\n \"Headers\" in fetchImpl &&\n \"Request\" in fetchImpl &&\n \"Response\" in fetchImpl);\n};\nexports._globalFetchImplementationIsNodeFetch = _globalFetchImplementationIsNodeFetch;\n/**\n * @internal\n */\nconst _getFetchImplementation = (debug) => {\n return async (...args) => {\n if (debug || (0, env_js_1.getLangSmithEnvironmentVariable)(\"DEBUG\") === \"true\") {\n const [url, options] = args;\n console.log(`→ ${options?.method || \"GET\"} ${url}`);\n }\n const res = await (globalThis[LANGSMITH_FETCH_IMPLEMENTATION_KEY] ??\n DEFAULT_FETCH_IMPLEMENTATION)(...args);\n if (debug || (0, env_js_1.getLangSmithEnvironmentVariable)(\"DEBUG\") === \"true\") {\n console.log(`← ${res.status} ${res.statusText} ${res.url}`);\n }\n return res;\n };\n};\nexports._getFetchImplementation = _getFetchImplementation;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getDefaultProjectName = void 0;\nconst env_js_1 = require(\"./env.cjs\");\nconst getDefaultProjectName = () => {\n return ((0, env_js_1.getLangSmithEnvironmentVariable)(\"PROJECT\") ??\n (0, env_js_1.getEnvironmentVariable)(\"LANGCHAIN_SESSION\") ?? // TODO: Deprecate\n \"default\");\n};\nexports.getDefaultProjectName = getDefaultProjectName;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.warnOnce = warnOnce;\nconst warnedMessages = {};\nfunction warnOnce(message) {\n if (!warnedMessages[message]) {\n console.warn(message);\n warnedMessages[message] = true;\n }\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.assertUuid = assertUuid;\nexports.uuid7FromTime = uuid7FromTime;\nexports.getUuidVersion = getUuidVersion;\nexports.warnIfNotUuidV7 = warnIfNotUuidV7;\n// Relaxed UUID validation regex (allows any valid UUID format including nil UUIDs)\nconst UUID_REGEX = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i;\nconst uuid_1 = require(\"uuid\");\nconst warn_js_1 = require(\"./warn.cjs\");\nlet UUID7_WARNING_EMITTED = false;\nfunction assertUuid(str, which) {\n // Use relaxed regex validation instead of strict uuid.validate()\n // This allows edge cases like nil UUIDs or test UUIDs that might not pass strict validation\n if (!UUID_REGEX.test(str)) {\n const msg = which !== undefined\n ? `Invalid UUID for ${which}: ${str}`\n : `Invalid UUID: ${str}`;\n throw new Error(msg);\n }\n return str;\n}\n/**\n * Generate a UUID v7 from a timestamp.\n *\n * @param timestamp - The timestamp in milliseconds\n * @returns A UUID v7 string\n */\nfunction uuid7FromTime(timestamp) {\n const msecs = typeof timestamp === \"string\" ? Date.parse(timestamp) : timestamp;\n // Work around uuid@10 behavior where providing only { msecs }\n // may not set the internal timestamp used for stringification.\n // Providing a seq ensures the implementation updates its internal state\n // and encodes the provided milliseconds into the UUID bytes.\n return (0, uuid_1.v7)({ msecs, seq: 0 });\n}\n/**\n * Get the version of a UUID string.\n * @param uuidStr - The UUID string to check\n * @returns The version number (1-7) or null if invalid\n */\nfunction getUuidVersion(uuidStr) {\n if (!UUID_REGEX.test(uuidStr)) {\n return null;\n }\n // Version is in bits 48-51\n // Format: xxxxxxxx-xxxx-Vxxx-xxxx-xxxxxxxxxxxx\n const versionChar = uuidStr[14];\n return parseInt(versionChar, 16);\n}\n/**\n * Warn if a UUID is not version 7.\n *\n * @param uuidStr - The UUID string to check\n * @param idType - The type of ID (e.g., \"run_id\", \"trace_id\") for the warning message\n */\nfunction warnIfNotUuidV7(uuidStr, _idType) {\n const version = getUuidVersion(uuidStr);\n if (version !== null && version !== 7 && !UUID7_WARNING_EMITTED) {\n UUID7_WARNING_EMITTED = true;\n (0, warn_js_1.warnOnce)(`LangSmith now uses UUID v7 for run and trace identifiers. ` +\n `This warning appears when passing custom IDs. ` +\n `Please use: import { uuidv7 } from 'langsmith'; const id = uuidv7(); ` +\n `Future versions will require UUID v7.`);\n }\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.uuid7FromTime = void 0;\nexports.uuid7 = uuid7;\nconst uuid_1 = require(\"uuid\");\nvar _uuid_js_1 = require(\"./utils/_uuid.cjs\");\nObject.defineProperty(exports, \"uuid7FromTime\", { enumerable: true, get: function () { return _uuid_js_1.uuid7FromTime; } });\n/**\n * Generate a random UUID v7 string.\n */\nfunction uuid7() {\n return (0, uuid_1.v7)();\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.__version__ = exports.uuid7FromTime = exports.uuid7 = exports.getDefaultProjectName = exports.overrideFetchImplementation = exports.RunTree = exports.Client = void 0;\nvar client_js_1 = require(\"./client.cjs\");\nObject.defineProperty(exports, \"Client\", { enumerable: true, get: function () { return client_js_1.Client; } });\nvar run_trees_js_1 = require(\"./run_trees.cjs\");\nObject.defineProperty(exports, \"RunTree\", { enumerable: true, get: function () { return run_trees_js_1.RunTree; } });\nvar fetch_js_1 = require(\"./singletons/fetch.cjs\");\nObject.defineProperty(exports, \"overrideFetchImplementation\", { enumerable: true, get: function () { return fetch_js_1.overrideFetchImplementation; } });\nvar project_js_1 = require(\"./utils/project.cjs\");\nObject.defineProperty(exports, \"getDefaultProjectName\", { enumerable: true, get: function () { return project_js_1.getDefaultProjectName; } });\nvar uuid_js_1 = require(\"./uuid.cjs\");\nObject.defineProperty(exports, \"uuid7\", { enumerable: true, get: function () { return uuid_js_1.uuid7; } });\nObject.defineProperty(exports, \"uuid7FromTime\", { enumerable: true, get: function () { return uuid_js_1.uuid7FromTime; } });\n// Update using yarn bump-version\nexports.__version__ = \"0.3.87\";\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getEnv = exports.isNode = exports.isDeno = exports.isJsDom = exports.isWebWorker = exports.isBrowser = void 0;\nexports.getRuntimeEnvironment = getRuntimeEnvironment;\nexports.getLangSmithEnvVarsMetadata = getLangSmithEnvVarsMetadata;\nexports.getLangSmithEnvironmentVariables = getLangSmithEnvironmentVariables;\nexports.getEnvironmentVariable = getEnvironmentVariable;\nexports.getLangSmithEnvironmentVariable = getLangSmithEnvironmentVariable;\nexports.setEnvironmentVariable = setEnvironmentVariable;\nexports.getShas = getShas;\nexports.getOtelEnabled = getOtelEnabled;\n// Inlined from https://github.com/flexdinesh/browser-or-node\nconst index_js_1 = require(\"../index.cjs\");\nlet globalEnv;\nconst isBrowser = () => typeof window !== \"undefined\" && typeof window.document !== \"undefined\";\nexports.isBrowser = isBrowser;\nconst isWebWorker = () => typeof globalThis === \"object\" &&\n globalThis.constructor &&\n globalThis.constructor.name === \"DedicatedWorkerGlobalScope\";\nexports.isWebWorker = isWebWorker;\nconst isJsDom = () => (typeof window !== \"undefined\" && window.name === \"nodejs\") ||\n (typeof navigator !== \"undefined\" && navigator.userAgent.includes(\"jsdom\"));\nexports.isJsDom = isJsDom;\n// Supabase Edge Function provides a `Deno` global object\n// without `version` property\nconst isDeno = () => typeof Deno !== \"undefined\";\nexports.isDeno = isDeno;\n// Mark not-as-node if in Supabase Edge Function\nconst isNode = () => typeof process !== \"undefined\" &&\n typeof process.versions !== \"undefined\" &&\n typeof process.versions.node !== \"undefined\" &&\n !(0, exports.isDeno)();\nexports.isNode = isNode;\nconst getEnv = () => {\n if (globalEnv) {\n return globalEnv;\n }\n // @ts-expect-error Bun types are not imported due to conflicts with Node types\n if (typeof Bun !== \"undefined\") {\n globalEnv = \"bun\";\n }\n else if ((0, exports.isBrowser)()) {\n globalEnv = \"browser\";\n }\n else if ((0, exports.isNode)()) {\n globalEnv = \"node\";\n }\n else if ((0, exports.isWebWorker)()) {\n globalEnv = \"webworker\";\n }\n else if ((0, exports.isJsDom)()) {\n globalEnv = \"jsdom\";\n }\n else if ((0, exports.isDeno)()) {\n globalEnv = \"deno\";\n }\n else {\n globalEnv = \"other\";\n }\n return globalEnv;\n};\nexports.getEnv = getEnv;\nlet runtimeEnvironment;\nfunction getRuntimeEnvironment() {\n if (runtimeEnvironment === undefined) {\n const env = (0, exports.getEnv)();\n const releaseEnv = getShas();\n runtimeEnvironment = {\n library: \"langsmith\",\n runtime: env,\n sdk: \"langsmith-js\",\n sdk_version: index_js_1.__version__,\n ...releaseEnv,\n };\n }\n return runtimeEnvironment;\n}\n/**\n * Retrieves the LangSmith-specific metadata from the current runtime environment.\n *\n * @returns {Record<string, string>}\n * - A record of LangSmith-specific metadata environment variables.\n */\nfunction getLangSmithEnvVarsMetadata() {\n const allEnvVars = getLangSmithEnvironmentVariables();\n const envVars = {};\n const excluded = [\n \"LANGCHAIN_API_KEY\",\n \"LANGCHAIN_ENDPOINT\",\n \"LANGCHAIN_TRACING_V2\",\n \"LANGCHAIN_PROJECT\",\n \"LANGCHAIN_SESSION\",\n \"LANGSMITH_API_KEY\",\n \"LANGSMITH_ENDPOINT\",\n \"LANGSMITH_TRACING_V2\",\n \"LANGSMITH_PROJECT\",\n \"LANGSMITH_SESSION\",\n ];\n for (const [key, value] of Object.entries(allEnvVars)) {\n if (typeof value === \"string\" &&\n !excluded.includes(key) &&\n !key.toLowerCase().includes(\"key\") &&\n !key.toLowerCase().includes(\"secret\") &&\n !key.toLowerCase().includes(\"token\")) {\n if (key === \"LANGCHAIN_REVISION_ID\") {\n envVars[\"revision_id\"] = value;\n }\n else {\n envVars[key] = value;\n }\n }\n }\n return envVars;\n}\n/**\n * Retrieves only the LangChain/LangSmith-prefixed environment variables from the current runtime environment.\n * This is more efficient than copying all environment variables.\n *\n * @returns {Record<string, string>}\n * - A record of LangChain/LangSmith environment variables.\n */\nfunction getLangSmithEnvironmentVariables() {\n const envVars = {};\n try {\n // Check for Node.js environment\n // eslint-disable-next-line no-process-env\n if (typeof process !== \"undefined\" && process.env) {\n // eslint-disable-next-line no-process-env\n for (const [key, value] of Object.entries(process.env)) {\n if ((key.startsWith(\"LANGCHAIN_\") || key.startsWith(\"LANGSMITH_\")) &&\n value != null) {\n if ((key.toLowerCase().includes(\"key\") ||\n key.toLowerCase().includes(\"secret\") ||\n key.toLowerCase().includes(\"token\")) &&\n typeof value === \"string\") {\n envVars[key] =\n value.slice(0, 2) +\n \"*\".repeat(value.length - 4) +\n value.slice(-2);\n }\n else {\n envVars[key] = value;\n }\n }\n }\n }\n }\n catch (e) {\n // Catch any errors that might occur while trying to access environment variables\n }\n return envVars;\n}\nfunction getEnvironmentVariable(name) {\n // Certain Deno setups will throw an error if you try to access environment variables\n // https://github.com/hwchase17/langchainjs/issues/1412\n try {\n return typeof process !== \"undefined\"\n ? // eslint-disable-next-line no-process-env\n process.env?.[name]\n : undefined;\n }\n catch (e) {\n return undefined;\n }\n}\nfunction getLangSmithEnvironmentVariable(name) {\n return (getEnvironmentVariable(`LANGSMITH_${name}`) ||\n getEnvironmentVariable(`LANGCHAIN_${name}`));\n}\nfunction setEnvironmentVariable(name, value) {\n if (typeof process !== \"undefined\") {\n // eslint-disable-next-line no-process-env\n process.env[name] = value;\n }\n}\nlet cachedCommitSHAs;\n/**\n * Get the Git commit SHA from common environment variables\n * used by different CI/CD platforms.\n * @returns {string | undefined} The Git commit SHA or undefined if not found.\n */\nfunction getShas() {\n if (cachedCommitSHAs !== undefined) {\n return cachedCommitSHAs;\n }\n const common_release_envs = [\n \"VERCEL_GIT_COMMIT_SHA\",\n \"NEXT_PUBLIC_VERCEL_GIT_COMMIT_SHA\",\n \"COMMIT_REF\",\n \"RENDER_GIT_COMMIT\",\n \"CI_COMMIT_SHA\",\n \"CIRCLE_SHA1\",\n \"CF_PAGES_COMMIT_SHA\",\n \"REACT_APP_GIT_SHA\",\n \"SOURCE_VERSION\",\n \"GITHUB_SHA\",\n \"TRAVIS_COMMIT\",\n \"GIT_COMMIT\",\n \"BUILD_VCS_NUMBER\",\n \"bamboo_planRepository_revision\",\n \"Build.SourceVersion\",\n \"BITBUCKET_COMMIT\",\n \"DRONE_COMMIT_SHA\",\n \"SEMAPHORE_GIT_SHA\",\n \"BUILDKITE_COMMIT\",\n ];\n const shas = {};\n for (const env of common_release_envs) {\n const envVar = getEnvironmentVariable(env);\n if (envVar !== undefined) {\n shas[env] = envVar;\n }\n }\n cachedCommitSHAs = shas;\n return shas;\n}\nfunction getOtelEnabled() {\n return (getEnvironmentVariable(\"OTEL_ENABLED\") === \"true\" ||\n getLangSmithEnvironmentVariable(\"OTEL_ENABLED\") === \"true\");\n}\n","\"use strict\";\n// Should not import any OTEL packages to avoid pulling in optional deps.\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.OTELProviderSingleton = void 0;\nexports.getOTELTrace = getOTELTrace;\nexports.getOTELContext = getOTELContext;\nexports.setOTELInstances = setOTELInstances;\nexports.setDefaultOTLPTracerComponents = setDefaultOTLPTracerComponents;\nexports.getDefaultOTLPTracerComponents = getDefaultOTLPTracerComponents;\nconst env_js_1 = require(\"../utils/env.cjs\");\nclass MockTracer {\n constructor() {\n Object.defineProperty(this, \"hasWarned\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n }\n startActiveSpan(_name, ...args) {\n if (!this.hasWarned && (0, env_js_1.getOtelEnabled)()) {\n console.warn(\"You have enabled OTEL export via the `OTEL_ENABLED` or `LANGSMITH_OTEL_ENABLED` environment variable, but have not initialized the required OTEL instances. \" +\n 'Please add:\\n```\\nimport { initializeOTEL } from \"langsmith/experimental/otel/setup\";\\ninitializeOTEL();\\n```\\nat the beginning of your code.');\n this.hasWarned = true;\n }\n // Handle different overloads:\n // startActiveSpan(name, fn)\n // startActiveSpan(name, options, fn)\n // startActiveSpan(name, options, context, fn)\n let fn;\n if (args.length === 1 && typeof args[0] === \"function\") {\n fn = args[0];\n }\n else if (args.length === 2 && typeof args[1] === \"function\") {\n fn = args[1];\n }\n else if (args.length === 3 && typeof args[2] === \"function\") {\n fn = args[2];\n }\n if (typeof fn === \"function\") {\n return fn();\n }\n return undefined;\n }\n}\nclass MockOTELTrace {\n constructor() {\n Object.defineProperty(this, \"mockTracer\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: new MockTracer()\n });\n }\n getTracer(_name, _version) {\n return this.mockTracer;\n }\n getActiveSpan() {\n return undefined;\n }\n setSpan(context, _span) {\n return context;\n }\n getSpan(_context) {\n return undefined;\n }\n setSpanContext(context, _spanContext) {\n return context;\n }\n getTracerProvider() {\n return undefined;\n }\n setGlobalTracerProvider(_tracerProvider) {\n return false;\n }\n}\nclass MockOTELContext {\n active() {\n return {};\n }\n with(_context, fn) {\n return fn();\n }\n}\nconst OTEL_TRACE_KEY = Symbol.for(\"ls:otel_trace\");\nconst OTEL_CONTEXT_KEY = Symbol.for(\"ls:otel_context\");\nconst OTEL_GET_DEFAULT_OTLP_TRACER_PROVIDER_KEY = Symbol.for(\"ls:otel_get_default_otlp_tracer_provider\");\nconst mockOTELTrace = new MockOTELTrace();\nconst mockOTELContext = new MockOTELContext();\nclass OTELProvider {\n getTraceInstance() {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return globalThis[OTEL_TRACE_KEY] ?? mockOTELTrace;\n }\n getContextInstance() {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return globalThis[OTEL_CONTEXT_KEY] ?? mockOTELContext;\n }\n initializeGlobalInstances(otel) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (globalThis[OTEL_TRACE_KEY] === undefined) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n globalThis[OTEL_TRACE_KEY] = otel.trace;\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (globalThis[OTEL_CONTEXT_KEY] === undefined) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n globalThis[OTEL_CONTEXT_KEY] = otel.context;\n }\n }\n setDefaultOTLPTracerComponents(components) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n globalThis[OTEL_GET_DEFAULT_OTLP_TRACER_PROVIDER_KEY] = components;\n }\n getDefaultOTLPTracerComponents() {\n return (globalThis[OTEL_GET_DEFAULT_OTLP_TRACER_PROVIDER_KEY] ??\n undefined);\n }\n}\nexports.OTELProviderSingleton = new OTELProvider();\n/**\n * Get the current OTEL trace instance.\n * Returns a mock implementation if OTEL is not available.\n */\nfunction getOTELTrace() {\n return exports.OTELProviderSingleton.getTraceInstance();\n}\n/**\n * Get the current OTEL context instance.\n * Returns a mock implementation if OTEL is not available.\n */\nfunction getOTELContext() {\n return exports.OTELProviderSingleton.getContextInstance();\n}\n/**\n * Initialize the global OTEL instances.\n * Should be called once when OTEL packages are available.\n */\nfunction setOTELInstances(otel) {\n exports.OTELProviderSingleton.initializeGlobalInstances(otel);\n}\n/**\n * Set a getter function for the default OTLP tracer provider.\n * This allows lazy initialization of the tracer provider.\n */\nfunction setDefaultOTLPTracerComponents(components) {\n exports.OTELProviderSingleton.setDefaultOTLPTracerComponents(components);\n}\n/**\n * Get the default OTLP tracer provider instance.\n * Returns undefined if not set.\n */\nfunction getDefaultOTLPTracerComponents() {\n return exports.OTELProviderSingleton.getDefaultOTLPTracerComponents();\n}\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || (function () {\n var ownKeys = function(o) {\n ownKeys = Object.getOwnPropertyNames || function (o) {\n var ar = [];\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\n return ar;\n };\n return ownKeys(o);\n };\n return function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\n __setModuleDefault(result, mod);\n return result;\n };\n})();\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.LangSmithToOTELTranslator = void 0;\nconst constants = __importStar(require(\"./constants.cjs\"));\nconst otel_js_1 = require(\"../../singletons/otel.cjs\");\nconst WELL_KNOWN_OPERATION_NAMES = {\n llm: \"chat\",\n tool: \"execute_tool\",\n retriever: \"embeddings\",\n embedding: \"embeddings\",\n prompt: \"chat\",\n};\nfunction getOperationName(runType) {\n return WELL_KNOWN_OPERATION_NAMES[runType] || runType;\n}\nclass LangSmithToOTELTranslator {\n constructor() {\n Object.defineProperty(this, \"spans\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: new Map()\n });\n }\n exportBatch(operations, otelContextMap) {\n for (const op of operations) {\n try {\n if (!op.run) {\n continue;\n }\n if (op.operation === \"post\") {\n const span = this.createSpanForRun(op, op.run, otelContextMap.get(op.id));\n if (span && !op.run.end_time) {\n this.spans.set(op.id, span);\n }\n }\n else {\n this.updateSpanForRun(op, op.run);\n }\n }\n catch (e) {\n console.error(`Error processing operation ${op.id}:`, e);\n }\n }\n }\n createSpanForRun(op, runInfo, otelContext) {\n const activeSpan = otelContext && (0, otel_js_1.getOTELTrace)().getSpan(otelContext);\n if (!activeSpan) {\n return;\n }\n try {\n return this.finishSpanSetup(activeSpan, runInfo, op);\n }\n catch (e) {\n console.error(`Failed to create span for run ${op.id}:`, e);\n return undefined;\n }\n }\n finishSpanSetup(span, runInfo, op) {\n // Set all attributes\n this.setSpanAttributes(span, runInfo, op);\n // Set status based on error\n if (runInfo.error) {\n span.setStatus({ code: 2 }); // ERROR status\n span.recordException(new Error(runInfo.error));\n }\n else {\n span.setStatus({ code: 1 }); // OK status\n }\n // End the span if end_time is present\n if (runInfo.end_time) {\n span.end(new Date(runInfo.end_time));\n }\n return span;\n }\n updateSpanForRun(op, runInfo) {\n try {\n const span = this.spans.get(op.id);\n if (!span) {\n console.debug(`No span found for run ${op.id} during update`);\n return;\n }\n // Update attributes\n this.setSpanAttributes(span, runInfo, op);\n // Update status based on error\n if (runInfo.error) {\n span.setStatus({ code: 2 }); // ERROR status\n span.recordException(new Error(runInfo.error));\n }\n else {\n span.setStatus({ code: 1 }); // OK status\n }\n // End the span if end_time is present\n const endTime = runInfo.end_time;\n if (endTime) {\n span.end(new Date(endTime));\n this.spans.delete(op.id);\n }\n }\n catch (e) {\n console.error(`Failed to update span for run ${op.id}:`, e);\n }\n }\n extractModelName(runInfo) {\n // Try to get model name from metadata\n if (runInfo.extra?.metadata) {\n const metadata = runInfo.extra.metadata;\n // First check for ls_model_name in metadata\n if (metadata.ls_model_name) {\n return metadata.ls_model_name;\n }\n // Then check invocation_params for model info\n if (metadata.invocation_params) {\n const invocationParams = metadata.invocation_params;\n if (invocationParams.model) {\n return invocationParams.model;\n }\n else if (invocationParams.model_name) {\n return invocationParams.model_name;\n }\n }\n }\n return;\n }\n setSpanAttributes(span, runInfo, op) {\n if (\"run_type\" in runInfo && runInfo.run_type) {\n span.setAttribute(constants.LANGSMITH_RUN_TYPE, runInfo.run_type);\n // Set GenAI attributes according to OTEL semantic conventions\n const operationName = getOperationName(runInfo.run_type || \"chain\");\n span.setAttribute(constants.GEN_AI_OPERATION_NAME, operationName);\n }\n if (\"name\" in runInfo && runInfo.name) {\n span.setAttribute(constants.LANGSMITH_NAME, runInfo.name);\n }\n if (\"session_id\" in runInfo && runInfo.session_id) {\n span.setAttribute(constants.LANGSMITH_SESSION_ID, runInfo.session_id);\n }\n if (\"session_name\" in runInfo && runInfo.session_name) {\n span.setAttribute(constants.LANGSMITH_SESSION_NAME, runInfo.session_name);\n }\n // Set gen_ai.system\n this.setGenAiSystem(span, runInfo);\n // Set model name if available\n const modelName = this.extractModelName(runInfo);\n if (modelName) {\n span.setAttribute(constants.GEN_AI_REQUEST_MODEL, modelName);\n }\n // Set token usage information\n if (\"prompt_tokens\" in runInfo &&\n typeof runInfo.prompt_tokens === \"number\") {\n span.setAttribute(constants.GEN_AI_USAGE_INPUT_TOKENS, runInfo.prompt_tokens);\n }\n if (\"completion_tokens\" in runInfo &&\n typeof runInfo.completion_tokens === \"number\") {\n span.setAttribute(constants.GEN_AI_USAGE_OUTPUT_TOKENS, runInfo.completion_tokens);\n }\n if (\"total_tokens\" in runInfo && typeof runInfo.total_tokens === \"number\") {\n span.setAttribute(constants.GEN_AI_USAGE_TOTAL_TOKENS, runInfo.total_tokens);\n }\n // Set other parameters from invocation_params\n this.setInvocationParameters(span, runInfo);\n // Set metadata and tags if available\n const metadata = runInfo.extra?.metadata || {};\n for (const [key, value] of Object.entries(metadata)) {\n if (value !== null && value !== undefined) {\n span.setAttribute(`${constants.LANGSMITH_METADATA}.${key}`, String(value));\n }\n }\n const tags = runInfo.tags;\n if (tags && Array.isArray(tags)) {\n span.setAttribute(constants.LANGSMITH_TAGS, tags.join(\", \"));\n }\n else if (tags) {\n span.setAttribute(constants.LANGSMITH_TAGS, String(tags));\n }\n // Support additional serialized attributes, if present\n if (\"serialized\" in runInfo && typeof runInfo.serialized === \"object\") {\n const serialized = runInfo.serialized;\n if (serialized.name) {\n span.setAttribute(constants.GEN_AI_SERIALIZED_NAME, String(serialized.name));\n }\n if (serialized.signature) {\n span.setAttribute(constants.GEN_AI_SERIALIZED_SIGNATURE, String(serialized.signature));\n }\n if (serialized.doc) {\n span.setAttribute(constants.GEN_AI_SERIALIZED_DOC, String(serialized.doc));\n }\n }\n // Set inputs/outputs if available\n this.setIOAttributes(span, op);\n }\n setGenAiSystem(span, runInfo) {\n // Default to \"langchain\" if we can't determine the system\n let system = \"langchain\";\n // Extract model name to determine the system\n const modelName = this.extractModelName(runInfo);\n if (modelName) {\n const modelLower = modelName.toLowerCase();\n if (modelLower.includes(\"anthropic\") || modelLower.startsWith(\"claude\")) {\n system = \"anthropic\";\n }\n else if (modelLower.includes(\"bedrock\")) {\n system = \"aws.bedrock\";\n }\n else if (modelLower.includes(\"azure\") &&\n modelLower.includes(\"openai\")) {\n system = \"az.ai.openai\";\n }\n else if (modelLower.includes(\"azure\") &&\n modelLower.includes(\"inference\")) {\n system = \"az.ai.inference\";\n }\n else if (modelLower.includes(\"cohere\")) {\n system = \"cohere\";\n }\n else if (modelLower.includes(\"deepseek\")) {\n system = \"deepseek\";\n }\n else if (modelLower.includes(\"gemini\")) {\n system = \"gemini\";\n }\n else if (modelLower.includes(\"groq\")) {\n system = \"groq\";\n }\n else if (modelLower.includes(\"watson\") || modelLower.includes(\"ibm\")) {\n system = \"ibm.watsonx.ai\";\n }\n else if (modelLower.includes(\"mistral\")) {\n system = \"mistral_ai\";\n }\n else if (modelLower.includes(\"gpt\") || modelLower.includes(\"openai\")) {\n system = \"openai\";\n }\n else if (modelLower.includes(\"perplexity\") ||\n modelLower.includes(\"sonar\")) {\n system = \"perplexity\";\n }\n else if (modelLower.includes(\"vertex\")) {\n system = \"vertex_ai\";\n }\n else if (modelLower.includes(\"xai\") || modelLower.includes(\"grok\")) {\n system = \"xai\";\n }\n }\n span.setAttribute(constants.GEN_AI_SYSTEM, system);\n }\n setInvocationParameters(span, runInfo) {\n if (!runInfo.extra?.metadata?.invocation_params) {\n return;\n }\n const invocationParams = runInfo.extra.metadata.invocation_params;\n // Set relevant invocation parameters\n if (invocationParams.max_tokens !== undefined) {\n span.setAttribute(constants.GEN_AI_REQUEST_MAX_TOKENS, invocationParams.max_tokens);\n }\n if (invocationParams.temperature !== undefined) {\n span.setAttribute(constants.GEN_AI_REQUEST_TEMPERATURE, invocationParams.temperature);\n }\n if (invocationParams.top_p !== undefined) {\n span.setAttribute(constants.GEN_AI_REQUEST_TOP_P, invocationParams.top_p);\n }\n if (invocationParams.frequency_penalty !== undefined) {\n span.setAttribute(constants.GEN_AI_REQUEST_FREQUENCY_PENALTY, invocationParams.frequency_penalty);\n }\n if (invocationParams.presence_penalty !== undefined) {\n span.setAttribute(constants.GEN_AI_REQUEST_PRESENCE_PENALTY, invocationParams.presence_penalty);\n }\n }\n setIOAttributes(span, op) {\n if (op.run.inputs) {\n try {\n const inputs = op.run.inputs;\n if (typeof inputs === \"object\" && inputs !== null) {\n if (inputs.model && Array.isArray(inputs.messages)) {\n span.setAttribute(constants.GEN_AI_REQUEST_MODEL, inputs.model);\n }\n // Set additional request attributes if available\n if (inputs.stream !== undefined) {\n span.setAttribute(constants.LANGSMITH_REQUEST_STREAMING, inputs.stream);\n }\n if (inputs.extra_headers) {\n span.setAttribute(constants.LANGSMITH_REQUEST_HEADERS, JSON.stringify(inputs.extra_headers));\n }\n if (inputs.extra_query) {\n span.setAttribute(constants.GEN_AI_REQUEST_EXTRA_QUERY, JSON.stringify(inputs.extra_query));\n }\n if (inputs.extra_body) {\n span.setAttribute(constants.GEN_AI_REQUEST_EXTRA_BODY, JSON.stringify(inputs.extra_body));\n }\n }\n span.setAttribute(constants.GENAI_PROMPT, JSON.stringify(inputs));\n }\n catch (e) {\n console.debug(`Failed to process inputs for run ${op.id}`, e);\n }\n }\n if (op.run.outputs) {\n try {\n const outputs = op.run.outputs;\n // Extract token usage from outputs (for LLM runs)\n const tokenUsage = this.getUnifiedRunTokens(outputs);\n if (tokenUsage) {\n span.setAttribute(constants.GEN_AI_USAGE_INPUT_TOKENS, tokenUsage[0]);\n span.setAttribute(constants.GEN_AI_USAGE_OUTPUT_TOKENS, tokenUsage[1]);\n span.setAttribute(constants.GEN_AI_USAGE_TOTAL_TOKENS, tokenUsage[0] + tokenUsage[1]);\n }\n if (outputs && typeof outputs === \"object\") {\n if (outputs.model) {\n span.setAttribute(constants.GEN_AI_RESPONSE_MODEL, String(outputs.model));\n }\n // Extract additional response attributes\n if (outputs.id) {\n span.setAttribute(constants.GEN_AI_RESPONSE_ID, outputs.id);\n }\n if (outputs.choices && Array.isArray(outputs.choices)) {\n const finishReasons = outputs.choices\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .map((choice) => choice.finish_reason)\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n .filter((reason) => reason)\n .map(String);\n if (finishReasons.length > 0) {\n span.setAttribute(constants.GEN_AI_RESPONSE_FINISH_REASONS, finishReasons.join(\", \"));\n }\n }\n if (outputs.service_tier) {\n span.setAttribute(constants.GEN_AI_RESPONSE_SERVICE_TIER, outputs.service_tier);\n }\n if (outputs.system_fingerprint) {\n span.setAttribute(constants.GEN_AI_RESPONSE_SYSTEM_FINGERPRINT, outputs.system_fingerprint);\n }\n if (outputs.usage_metadata &&\n typeof outputs.usage_metadata === \"object\") {\n const usageMetadata = outputs.usage_metadata;\n if (usageMetadata.input_token_details) {\n span.setAttribute(constants.GEN_AI_USAGE_INPUT_TOKEN_DETAILS, JSON.stringify(usageMetadata.input_token_details));\n }\n if (usageMetadata.output_token_details) {\n span.setAttribute(constants.GEN_AI_USAGE_OUTPUT_TOKEN_DETAILS, JSON.stringify(usageMetadata.output_token_details));\n }\n }\n }\n span.setAttribute(constants.GENAI_COMPLETION, JSON.stringify(outputs));\n }\n catch (e) {\n console.debug(`Failed to process outputs for run ${op.id}`, e);\n }\n }\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n getUnifiedRunTokens(outputs) {\n if (!outputs) {\n return null;\n }\n // Search in non-generations lists\n let tokenUsage = this.extractUnifiedRunTokens(outputs.usage_metadata);\n if (tokenUsage) {\n return tokenUsage;\n }\n // Find if direct kwarg in outputs\n const keys = Object.keys(outputs);\n for (const key of keys) {\n const haystack = outputs[key];\n if (!haystack || typeof haystack !== \"object\") {\n continue;\n }\n tokenUsage = this.extractUnifiedRunTokens(haystack.usage_metadata);\n if (tokenUsage) {\n return tokenUsage;\n }\n if (haystack.lc === 1 &&\n haystack.kwargs &&\n typeof haystack.kwargs === \"object\") {\n tokenUsage = this.extractUnifiedRunTokens(haystack.kwargs.usage_metadata);\n if (tokenUsage) {\n return tokenUsage;\n }\n }\n }\n // Find in generations\n const generations = outputs.generations || [];\n if (!Array.isArray(generations)) {\n return null;\n }\n const flatGenerations = Array.isArray(generations[0])\n ? generations.flat()\n : generations;\n for (const generation of flatGenerations) {\n if (typeof generation === \"object\" &&\n generation.message &&\n typeof generation.message === \"object\" &&\n generation.message.kwargs &&\n typeof generation.message.kwargs === \"object\") {\n tokenUsage = this.extractUnifiedRunTokens(generation.message.kwargs.usage_metadata);\n if (tokenUsage) {\n return tokenUsage;\n }\n }\n }\n return null;\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n extractUnifiedRunTokens(outputs) {\n if (!outputs || typeof outputs !== \"object\") {\n return null;\n }\n if (typeof outputs.input_tokens !== \"number\" ||\n typeof outputs.output_tokens !== \"number\") {\n return null;\n }\n return [outputs.input_tokens, outputs.output_tokens];\n }\n}\nexports.LangSmithToOTELTranslator = LangSmithToOTELTranslator;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.default = isNetworkError;\n/* eslint-disable */\n// @ts-nocheck\n// is-network-error vendored to avoid import issues\n// Source: https://github.com/sindresorhus/is-network-error\nconst objectToString = Object.prototype.toString;\nconst isError = (value) => objectToString.call(value) === \"[object Error]\";\nconst errorMessages = new Set([\n \"network error\", // Chrome\n \"Failed to fetch\", // Chrome\n \"NetworkError when attempting to fetch resource.\", // Firefox\n \"The Internet connection appears to be offline.\", // Safari 16\n \"Network request failed\", // `cross-fetch`\n \"fetch failed\", // Undici (Node.js)\n \"terminated\", // Undici (Node.js)\n \" A network error occurred.\", // Bun (WebKit)\n \"Network connection lost\", // Cloudflare Workers (fetch)\n]);\nfunction isNetworkError(error) {\n const isValid = error &&\n isError(error) &&\n error.name === \"TypeError\" &&\n typeof error.message === \"string\";\n if (!isValid) {\n return false;\n }\n const { message, stack } = error;\n // Safari 17+ has generic message but no stack for network errors\n if (message === \"Load failed\") {\n return (stack === undefined ||\n // Sentry adds its own stack trace to the fetch error, so also check for that\n \"__sentry_captured__\" in error);\n }\n // Deno network errors start with specific text\n if (message.startsWith(\"error sending request for url\")) {\n return true;\n }\n // Standard network error messages\n return errorMessages.has(message);\n}\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.AbortError = void 0;\nexports.default = pRetry;\nexports.makeRetriable = makeRetriable;\n/* eslint-disable */\n// @ts-nocheck\n// p-retry code vendored to avoid import issues\n// Source: https://github.com/sindresorhus/p-retry\nconst index_js_1 = __importDefault(require(\"../is-network-error/index.cjs\"));\nfunction validateRetries(retries) {\n if (typeof retries === \"number\") {\n if (retries < 0) {\n throw new TypeError(\"Expected `retries` to be a non-negative number.\");\n }\n if (Number.isNaN(retries)) {\n throw new TypeError(\"Expected `retries` to be a valid number or Infinity, got NaN.\");\n }\n }\n else if (retries !== undefined) {\n throw new TypeError(\"Expected `retries` to be a number or Infinity.\");\n }\n}\nfunction validateNumberOption(name, value, { min = 0, allowInfinity = false } = {}) {\n if (value === undefined) {\n return;\n }\n if (typeof value !== \"number\" || Number.isNaN(value)) {\n throw new TypeError(`Expected \\`${name}\\` to be a number${allowInfinity ? \" or Infinity\" : \"\"}.`);\n }\n if (!allowInfinity && !Number.isFinite(value)) {\n throw new TypeError(`Expected \\`${name}\\` to be a finite number.`);\n }\n if (value < min) {\n throw new TypeError(`Expected \\`${name}\\` to be \\u2265 ${min}.`);\n }\n}\nclass AbortError extends Error {\n constructor(message) {\n super();\n if (message instanceof Error) {\n this.originalError = message;\n ({ message } = message);\n }\n else {\n this.originalError = new Error(message);\n this.originalError.stack = this.stack;\n }\n this.name = \"AbortError\";\n this.message = message;\n }\n}\nexports.AbortError = AbortError;\nfunction calculateDelay(retriesConsumed, options) {\n const attempt = Math.max(1, retriesConsumed + 1);\n const random = options.randomize ? Math.random() + 1 : 1;\n let timeout = Math.round(random * options.minTimeout * options.factor ** (attempt - 1));\n timeout = Math.min(timeout, options.maxTimeout);\n return timeout;\n}\nfunction calculateRemainingTime(start, max) {\n if (!Number.isFinite(max)) {\n return max;\n }\n return max - (performance.now() - start);\n}\nasync function onAttemptFailure({ error, attemptNumber, retriesConsumed, startTime, options, }) {\n const normalizedError = error instanceof Error\n ? error\n : new TypeError(`Non-error was thrown: \"${error}\". You should only throw errors.`);\n if (normalizedError instanceof AbortError) {\n throw normalizedError.originalError;\n }\n const retriesLeft = Number.isFinite(options.retries)\n ? Math.max(0, options.retries - retriesConsumed)\n : options.retries;\n const maxRetryTime = options.maxRetryTime ?? Number.POSITIVE_INFINITY;\n const context = Object.freeze({\n error: normalizedError,\n attemptNumber,\n retriesLeft,\n retriesConsumed,\n });\n await options.onFailedAttempt(context);\n if (calculateRemainingTime(startTime, maxRetryTime) <= 0) {\n throw normalizedError;\n }\n const consumeRetry = await options.shouldConsumeRetry(context);\n const remainingTime = calculateRemainingTime(startTime, maxRetryTime);\n if (remainingTime <= 0 || retriesLeft <= 0) {\n throw normalizedError;\n }\n if (normalizedError instanceof TypeError &&\n !(0, index_js_1.default)(normalizedError)) {\n if (consumeRetry) {\n throw normalizedError;\n }\n options.signal?.throwIfAborted();\n return false;\n }\n if (!(await options.shouldRetry(context))) {\n throw normalizedError;\n }\n if (!consumeRetry) {\n options.signal?.throwIfAborted();\n return false;\n }\n const delayTime = calculateDelay(retriesConsumed, options);\n const finalDelay = Math.min(delayTime, remainingTime);\n if (finalDelay > 0) {\n await new Promise((resolve, reject) => {\n const onAbort = () => {\n clearTimeout(timeoutToken);\n options.signal?.removeEventListener(\"abort\", onAbort);\n reject(options.signal.reason);\n };\n const timeoutToken = setTimeout(() => {\n options.signal?.removeEventListener(\"abort\", onAbort);\n resolve();\n }, finalDelay);\n if (options.unref) {\n timeoutToken.unref?.();\n }\n options.signal?.addEventListener(\"abort\", onAbort, { once: true });\n });\n }\n options.signal?.throwIfAborted();\n return true;\n}\nasync function pRetry(input, options = {}) {\n options = { ...options };\n validateRetries(options.retries);\n if (Object.hasOwn(options, \"forever\")) {\n throw new Error(\"The `forever` option is no longer supported. For many use-cases, you can set `retries: Infinity` instead.\");\n }\n options.retries ??= 10;\n options.factor ??= 2;\n options.minTimeout ??= 1000;\n options.maxTimeout ??= Number.POSITIVE_INFINITY;\n options.maxRetryTime ??= Number.POSITIVE_INFINITY;\n options.randomize ??= false;\n options.onFailedAttempt ??= () => { };\n options.shouldRetry ??= () => true;\n options.shouldConsumeRetry ??= () => true;\n // Validate numeric options and normalize edge cases\n validateNumberOption(\"factor\", options.factor, {\n min: 0,\n allowInfinity: false,\n });\n validateNumberOption(\"minTimeout\", options.minTimeout, {\n min: 0,\n allowInfinity: false,\n });\n validateNumberOption(\"maxTimeout\", options.maxTimeout, {\n min: 0,\n allowInfinity: true,\n });\n validateNumberOption(\"maxRetryTime\", options.maxRetryTime, {\n min: 0,\n allowInfinity: true,\n });\n // Treat non-positive factor as 1 to avoid zero backoff or negative behavior\n if (!(options.factor > 0)) {\n options.factor = 1;\n }\n options.signal?.throwIfAborted();\n let attemptNumber = 0;\n let retriesConsumed = 0;\n const startTime = performance.now();\n while (Number.isFinite(options.retries) ? retriesConsumed <= options.retries : true) {\n attemptNumber++;\n try {\n options.signal?.throwIfAborted();\n const result = await input(attemptNumber);\n options.signal?.throwIfAborted();\n return result;\n }\n catch (error) {\n if (await onAttemptFailure({\n error,\n attemptNumber,\n retriesConsumed,\n startTime,\n options,\n })) {\n retriesConsumed++;\n }\n }\n }\n // Should not reach here, but in case it does, throw an error\n throw new Error(\"Retry attempts exhausted without throwing an error.\");\n}\nfunction makeRetriable(function_, options) {\n return function (...arguments_) {\n return pRetry(() => function_.apply(this, arguments_), options);\n };\n}\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty\n , prefix = '~';\n\n/**\n * Constructor to create a storage for our `EE` objects.\n * An `Events` instance is a plain object whose properties are event names.\n *\n * @constructor\n * @private\n */\nfunction Events() {}\n\n//\n// We try to not inherit from `Object.prototype`. In some engines creating an\n// instance in this way is faster than calling `Object.create(null)` directly.\n// If `Object.create(null)` is not supported we prefix the event names with a\n// character to make sure that the built-in object properties are not\n// overridden or used as an attack vector.\n//\nif (Object.create) {\n Events.prototype = Object.create(null);\n\n //\n // This hack is needed because the `__proto__` property is still inherited in\n // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5.\n //\n if (!new Events().__proto__) prefix = false;\n}\n\n/**\n * Representation of a single event listener.\n *\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} [once=false] Specify if the listener is a one-time listener.\n * @constructor\n * @private\n */\nfunction EE(fn, context, once) {\n this.fn = fn;\n this.context = context;\n this.once = once || false;\n}\n\n/**\n * Add a listener for a given event.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} once Specify if the listener is a one-time listener.\n * @returns {EventEmitter}\n * @private\n */\nfunction addListener(emitter, event, fn, context, once) {\n if (typeof fn !== 'function') {\n throw new TypeError('The listener must be a function');\n }\n\n var listener = new EE(fn, context || emitter, once)\n , evt = prefix ? prefix + event : event;\n\n if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++;\n else if (!emitter._events[evt].fn) emitter._events[evt].push(listener);\n else emitter._events[evt] = [emitter._events[evt], listener];\n\n return emitter;\n}\n\n/**\n * Clear event by name.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} evt The Event name.\n * @private\n */\nfunction clearEvent(emitter, evt) {\n if (--emitter._eventsCount === 0) emitter._events = new Events();\n else delete emitter._events[evt];\n}\n\n/**\n * Minimal `EventEmitter` interface that is molded against the Node.js\n * `EventEmitter` interface.\n *\n * @constructor\n * @public\n */\nfunction EventEmitter() {\n this._events = new Events();\n this._eventsCount = 0;\n}\n\n/**\n * Return an array listing the events for which the emitter has registered\n * listeners.\n *\n * @returns {Array}\n * @public\n */\nEventEmitter.prototype.eventNames = function eventNames() {\n var names = []\n , events\n , name;\n\n if (this._eventsCount === 0) return names;\n\n for (name in (events = this._events)) {\n if (has.call(events, name)) names.push(prefix ? name.slice(1) : name);\n }\n\n if (Object.getOwnPropertySymbols) {\n return names.concat(Object.getOwnPropertySymbols(events));\n }\n\n return names;\n};\n\n/**\n * Return the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Array} The registered listeners.\n * @public\n */\nEventEmitter.prototype.listeners = function listeners(event) {\n var evt = prefix ? prefix + event : event\n , handlers = this._events[evt];\n\n if (!handlers) return [];\n if (handlers.fn) return [handlers.fn];\n\n for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) {\n ee[i] = handlers[i].fn;\n }\n\n return ee;\n};\n\n/**\n * Return the number of listeners listening to a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Number} The number of listeners.\n * @public\n */\nEventEmitter.prototype.listenerCount = function listenerCount(event) {\n var evt = prefix ? prefix + event : event\n , listeners = this._events[evt];\n\n if (!listeners) return 0;\n if (listeners.fn) return 1;\n return listeners.length;\n};\n\n/**\n * Calls each of the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Boolean} `true` if the event had listeners, else `false`.\n * @public\n */\nEventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return false;\n\n var listeners = this._events[evt]\n , len = arguments.length\n , args\n , i;\n\n if (listeners.fn) {\n if (listeners.once) this.removeListener(event, listeners.fn, undefined, true);\n\n switch (len) {\n case 1: return listeners.fn.call(listeners.context), true;\n case 2: return listeners.fn.call(listeners.context, a1), true;\n case 3: return listeners.fn.call(listeners.context, a1, a2), true;\n case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true;\n case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;\n case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;\n }\n\n for (i = 1, args = new Array(len -1); i < len; i++) {\n args[i - 1] = arguments[i];\n }\n\n listeners.fn.apply(listeners.context, args);\n } else {\n var length = listeners.length\n , j;\n\n for (i = 0; i < length; i++) {\n if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true);\n\n switch (len) {\n case 1: listeners[i].fn.call(listeners[i].context); break;\n case 2: listeners[i].fn.call(listeners[i].context, a1); break;\n case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break;\n case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break;\n default:\n if (!args) for (j = 1, args = new Array(len -1); j < len; j++) {\n args[j - 1] = arguments[j];\n }\n\n listeners[i].fn.apply(listeners[i].context, args);\n }\n }\n }\n\n return true;\n};\n\n/**\n * Add a listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.on = function on(event, fn, context) {\n return addListener(this, event, fn, context, false);\n};\n\n/**\n * Add a one-time listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.once = function once(event, fn, context) {\n return addListener(this, event, fn, context, true);\n};\n\n/**\n * Remove the listeners of a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn Only remove the listeners that match this function.\n * @param {*} context Only remove the listeners that have this context.\n * @param {Boolean} once Only remove one-time listeners.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return this;\n if (!fn) {\n clearEvent(this, evt);\n return this;\n }\n\n var listeners = this._events[evt];\n\n if (listeners.fn) {\n if (\n listeners.fn === fn &&\n (!once || listeners.once) &&\n (!context || listeners.context === context)\n ) {\n clearEvent(this, evt);\n }\n } else {\n for (var i = 0, events = [], length = listeners.length; i < length; i++) {\n if (\n listeners[i].fn !== fn ||\n (once && !listeners[i].once) ||\n (context && listeners[i].context !== context)\n ) {\n events.push(listeners[i]);\n }\n }\n\n //\n // Reset the array, or remove it completely if we have no more listeners.\n //\n if (events.length) this._events[evt] = events.length === 1 ? events[0] : events;\n else clearEvent(this, evt);\n }\n\n return this;\n};\n\n/**\n * Remove all listeners, or those of the specified event.\n *\n * @param {(String|Symbol)} [event] The event name.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {\n var evt;\n\n if (event) {\n evt = prefix ? prefix + event : event;\n if (this._events[evt]) clearEvent(this, evt);\n } else {\n this._events = new Events();\n this._eventsCount = 0;\n }\n\n return this;\n};\n\n//\n// Alias methods names because people roll like that.\n//\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.addListener = EventEmitter.prototype.on;\n\n//\n// Expose the prefix.\n//\nEventEmitter.prefixed = prefix;\n\n//\n// Allow `EventEmitter` to be imported as module namespace.\n//\nEventEmitter.EventEmitter = EventEmitter;\n\n//\n// Expose the module.\n//\nif ('undefined' !== typeof module) {\n module.exports = EventEmitter;\n}\n","'use strict';\nmodule.exports = (promise, onFinally) => {\n\tonFinally = onFinally || (() => {});\n\n\treturn promise.then(\n\t\tval => new Promise(resolve => {\n\t\t\tresolve(onFinally());\n\t\t}).then(() => val),\n\t\terr => new Promise(resolve => {\n\t\t\tresolve(onFinally());\n\t\t}).then(() => {\n\t\t\tthrow err;\n\t\t})\n\t);\n};\n","'use strict';\n\nconst pFinally = require('p-finally');\n\nclass TimeoutError extends Error {\n\tconstructor(message) {\n\t\tsuper(message);\n\t\tthis.name = 'TimeoutError';\n\t}\n}\n\nconst pTimeout = (promise, milliseconds, fallback) => new Promise((resolve, reject) => {\n\tif (typeof milliseconds !== 'number' || milliseconds < 0) {\n\t\tthrow new TypeError('Expected `milliseconds` to be a positive number');\n\t}\n\n\tif (milliseconds === Infinity) {\n\t\tresolve(promise);\n\t\treturn;\n\t}\n\n\tconst timer = setTimeout(() => {\n\t\tif (typeof fallback === 'function') {\n\t\t\ttry {\n\t\t\t\tresolve(fallback());\n\t\t\t} catch (error) {\n\t\t\t\treject(error);\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\tconst message = typeof fallback === 'string' ? fallback : `Promise timed out after ${milliseconds} milliseconds`;\n\t\tconst timeoutError = fallback instanceof Error ? fallback : new TimeoutError(message);\n\n\t\tif (typeof promise.cancel === 'function') {\n\t\t\tpromise.cancel();\n\t\t}\n\n\t\treject(timeoutError);\n\t}, milliseconds);\n\n\t// TODO: Use native `finally` keyword when targeting Node.js 10\n\tpFinally(\n\t\t// eslint-disable-next-line promise/prefer-await-to-then\n\t\tpromise.then(resolve, reject),\n\t\t() => {\n\t\t\tclearTimeout(timer);\n\t\t}\n\t);\n});\n\nmodule.exports = pTimeout;\n// TODO: Remove this for the next major release\nmodule.exports.default = pTimeout;\n\nmodule.exports.TimeoutError = TimeoutError;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n// Port of lower_bound from https://en.cppreference.com/w/cpp/algorithm/lower_bound\n// Used to compute insertion index to keep queue sorted after insertion\nfunction lowerBound(array, value, comparator) {\n let first = 0;\n let count = array.length;\n while (count > 0) {\n const step = (count / 2) | 0;\n let it = first + step;\n if (comparator(array[it], value) <= 0) {\n first = ++it;\n count -= step + 1;\n }\n else {\n count = step;\n }\n }\n return first;\n}\nexports.default = lowerBound;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst lower_bound_1 = require(\"./lower-bound\");\nclass PriorityQueue {\n constructor() {\n this._queue = [];\n }\n enqueue(run, options) {\n options = Object.assign({ priority: 0 }, options);\n const element = {\n priority: options.priority,\n run\n };\n if (this.size && this._queue[this.size - 1].priority >= options.priority) {\n this._queue.push(element);\n return;\n }\n const index = lower_bound_1.default(this._queue, element, (a, b) => b.priority - a.priority);\n this._queue.splice(index, 0, element);\n }\n dequeue() {\n const item = this._queue.shift();\n return item === null || item === void 0 ? void 0 : item.run;\n }\n filter(options) {\n return this._queue.filter((element) => element.priority === options.priority).map((element) => element.run);\n }\n get size() {\n return this._queue.length;\n }\n}\nexports.default = PriorityQueue;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst EventEmitter = require(\"eventemitter3\");\nconst p_timeout_1 = require(\"p-timeout\");\nconst priority_queue_1 = require(\"./priority-queue\");\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nconst empty = () => { };\nconst timeoutError = new p_timeout_1.TimeoutError();\n/**\nPromise queue with concurrency control.\n*/\nclass PQueue extends EventEmitter {\n constructor(options) {\n var _a, _b, _c, _d;\n super();\n this._intervalCount = 0;\n this._intervalEnd = 0;\n this._pendingCount = 0;\n this._resolveEmpty = empty;\n this._resolveIdle = empty;\n // eslint-disable-next-line @typescript-eslint/consistent-type-assertions\n options = Object.assign({ carryoverConcurrencyCount: false, intervalCap: Infinity, interval: 0, concurrency: Infinity, autoStart: true, queueClass: priority_queue_1.default }, options);\n if (!(typeof options.intervalCap === 'number' && options.intervalCap >= 1)) {\n throw new TypeError(`Expected \\`intervalCap\\` to be a number from 1 and up, got \\`${(_b = (_a = options.intervalCap) === null || _a === void 0 ? void 0 : _a.toString()) !== null && _b !== void 0 ? _b : ''}\\` (${typeof options.intervalCap})`);\n }\n if (options.interval === undefined || !(Number.isFinite(options.interval) && options.interval >= 0)) {\n throw new TypeError(`Expected \\`interval\\` to be a finite number >= 0, got \\`${(_d = (_c = options.interval) === null || _c === void 0 ? void 0 : _c.toString()) !== null && _d !== void 0 ? _d : ''}\\` (${typeof options.interval})`);\n }\n this._carryoverConcurrencyCount = options.carryoverConcurrencyCount;\n this._isIntervalIgnored = options.intervalCap === Infinity || options.interval === 0;\n this._intervalCap = options.intervalCap;\n this._interval = options.interval;\n this._queue = new options.queueClass();\n this._queueClass = options.queueClass;\n this.concurrency = options.concurrency;\n this._timeout = options.timeout;\n this._throwOnTimeout = options.throwOnTimeout === true;\n this._isPaused = options.autoStart === false;\n }\n get _doesIntervalAllowAnother() {\n return this._isIntervalIgnored || this._intervalCount < this._intervalCap;\n }\n get _doesConcurrentAllowAnother() {\n return this._pendingCount < this._concurrency;\n }\n _next() {\n this._pendingCount--;\n this._tryToStartAnother();\n this.emit('next');\n }\n _resolvePromises() {\n this._resolveEmpty();\n this._resolveEmpty = empty;\n if (this._pendingCount === 0) {\n this._resolveIdle();\n this._resolveIdle = empty;\n this.emit('idle');\n }\n }\n _onResumeInterval() {\n this._onInterval();\n this._initializeIntervalIfNeeded();\n this._timeoutId = undefined;\n }\n _isIntervalPaused() {\n const now = Date.now();\n if (this._intervalId === undefined) {\n const delay = this._intervalEnd - now;\n if (delay < 0) {\n // Act as the interval was done\n // We don't need to resume it here because it will be resumed on line 160\n this._intervalCount = (this._carryoverConcurrencyCount) ? this._pendingCount : 0;\n }\n else {\n // Act as the interval is pending\n if (this._timeoutId === undefined) {\n this._timeoutId = setTimeout(() => {\n this._onResumeInterval();\n }, delay);\n }\n return true;\n }\n }\n return false;\n }\n _tryToStartAnother() {\n if (this._queue.size === 0) {\n // We can clear the interval (\"pause\")\n // Because we can redo it later (\"resume\")\n if (this._intervalId) {\n clearInterval(this._intervalId);\n }\n this._intervalId = undefined;\n this._resolvePromises();\n return false;\n }\n if (!this._isPaused) {\n const canInitializeInterval = !this._isIntervalPaused();\n if (this._doesIntervalAllowAnother && this._doesConcurrentAllowAnother) {\n const job = this._queue.dequeue();\n if (!job) {\n return false;\n }\n this.emit('active');\n job();\n if (canInitializeInterval) {\n this._initializeIntervalIfNeeded();\n }\n return true;\n }\n }\n return false;\n }\n _initializeIntervalIfNeeded() {\n if (this._isIntervalIgnored || this._intervalId !== undefined) {\n return;\n }\n this._intervalId = setInterval(() => {\n this._onInterval();\n }, this._interval);\n this._intervalEnd = Date.now() + this._interval;\n }\n _onInterval() {\n if (this._intervalCount === 0 && this._pendingCount === 0 && this._intervalId) {\n clearInterval(this._intervalId);\n this._intervalId = undefined;\n }\n this._intervalCount = this._carryoverConcurrencyCount ? this._pendingCount : 0;\n this._processQueue();\n }\n /**\n Executes all queued functions until it reaches the limit.\n */\n _processQueue() {\n // eslint-disable-next-line no-empty\n while (this._tryToStartAnother()) { }\n }\n get concurrency() {\n return this._concurrency;\n }\n set concurrency(newConcurrency) {\n if (!(typeof newConcurrency === 'number' && newConcurrency >= 1)) {\n throw new TypeError(`Expected \\`concurrency\\` to be a number from 1 and up, got \\`${newConcurrency}\\` (${typeof newConcurrency})`);\n }\n this._concurrency = newConcurrency;\n this._processQueue();\n }\n /**\n Adds a sync or async task to the queue. Always returns a promise.\n */\n async add(fn, options = {}) {\n return new Promise((resolve, reject) => {\n const run = async () => {\n this._pendingCount++;\n this._intervalCount++;\n try {\n const operation = (this._timeout === undefined && options.timeout === undefined) ? fn() : p_timeout_1.default(Promise.resolve(fn()), (options.timeout === undefined ? this._timeout : options.timeout), () => {\n if (options.throwOnTimeout === undefined ? this._throwOnTimeout : options.throwOnTimeout) {\n reject(timeoutError);\n }\n return undefined;\n });\n resolve(await operation);\n }\n catch (error) {\n reject(error);\n }\n this._next();\n };\n this._queue.enqueue(run, options);\n this._tryToStartAnother();\n this.emit('add');\n });\n }\n /**\n Same as `.add()`, but accepts an array of sync or async functions.\n\n @returns A promise that resolves when all functions are resolved.\n */\n async addAll(functions, options) {\n return Promise.all(functions.map(async (function_) => this.add(function_, options)));\n }\n /**\n Start (or resume) executing enqueued tasks within concurrency limit. No need to call this if queue is not paused (via `options.autoStart = false` or by `.pause()` method.)\n */\n start() {\n if (!this._isPaused) {\n return this;\n }\n this._isPaused = false;\n this._processQueue();\n return this;\n }\n /**\n Put queue execution on hold.\n */\n pause() {\n this._isPaused = true;\n }\n /**\n Clear the queue.\n */\n clear() {\n this._queue = new this._queueClass();\n }\n /**\n Can be called multiple times. Useful if you for example add additional items at a later time.\n\n @returns A promise that settles when the queue becomes empty.\n */\n async onEmpty() {\n // Instantly resolve if the queue is empty\n if (this._queue.size === 0) {\n return;\n }\n return new Promise(resolve => {\n const existingResolve = this._resolveEmpty;\n this._resolveEmpty = () => {\n existingResolve();\n resolve();\n };\n });\n }\n /**\n The difference with `.onEmpty` is that `.onIdle` guarantees that all work from the queue has finished. `.onEmpty` merely signals that the queue is empty, but it could mean that some promises haven't completed yet.\n\n @returns A promise that settles when the queue becomes empty, and all promises have completed; `queue.size === 0 && queue.pending === 0`.\n */\n async onIdle() {\n // Instantly resolve if none pending and if nothing else is queued\n if (this._pendingCount === 0 && this._queue.size === 0) {\n return;\n }\n return new Promise(resolve => {\n const existingResolve = this._resolveIdle;\n this._resolveIdle = () => {\n existingResolve();\n resolve();\n };\n });\n }\n /**\n Size of the queue.\n */\n get size() {\n return this._queue.size;\n }\n /**\n Size of the queue, filtered by the given options.\n\n For example, this can be used to find the number of items remaining in the queue with a specific priority level.\n */\n sizeBy(options) {\n // eslint-disable-next-line unicorn/no-fn-reference-in-iterator\n return this._queue.filter(options).length;\n }\n /**\n Number of pending promises.\n */\n get pending() {\n return this._pendingCount;\n }\n /**\n Whether the queue is currently paused.\n */\n get isPaused() {\n return this._isPaused;\n }\n get timeout() {\n return this._timeout;\n }\n /**\n Set the timeout for future operations.\n */\n set timeout(milliseconds) {\n this._timeout = milliseconds;\n }\n}\nexports.default = PQueue;\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.AsyncCaller = void 0;\nconst index_js_1 = __importDefault(require(\"../utils/p-retry/index.cjs\"));\nconst p_queue_1 = __importDefault(require(\"p-queue\"));\nconst STATUS_RETRYABLE = [\n 408, // Request Timeout\n 425, // Too Early\n 429, // Too Many Requests\n 500, // Internal Server Error\n 502, // Bad Gateway\n 503, // Service Unavailable\n 504, // Gateway Timeout\n];\n/**\n * A class that can be used to make async calls with concurrency and retry logic.\n *\n * This is useful for making calls to any kind of \"expensive\" external resource,\n * be it because it's rate-limited, subject to network issues, etc.\n *\n * Concurrent calls are limited by the `maxConcurrency` parameter, which defaults\n * to `Infinity`. This means that by default, all calls will be made in parallel.\n *\n * Retries are limited by the `maxRetries` parameter, which defaults to 6. This\n * means that by default, each call will be retried up to 6 times, with an\n * exponential backoff between each attempt.\n */\nclass AsyncCaller {\n constructor(params) {\n Object.defineProperty(this, \"maxConcurrency\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"maxRetries\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"maxQueueSizeBytes\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"queue\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"onFailedResponseHook\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"queueSizeBytes\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: 0\n });\n this.maxConcurrency = params.maxConcurrency ?? Infinity;\n this.maxRetries = params.maxRetries ?? 6;\n this.maxQueueSizeBytes = params.maxQueueSizeBytes;\n if (\"default\" in p_queue_1.default) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n this.queue = new p_queue_1.default.default({\n concurrency: this.maxConcurrency,\n });\n }\n else {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n this.queue = new p_queue_1.default({ concurrency: this.maxConcurrency });\n }\n this.onFailedResponseHook = params?.onFailedResponseHook;\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n call(callable, ...args) {\n return this.callWithOptions({}, callable, ...args);\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n callWithOptions(options, callable, ...args) {\n const sizeBytes = options.sizeBytes ?? 0;\n // Check if adding this call would exceed the byte size limit\n if (this.maxQueueSizeBytes !== undefined &&\n sizeBytes > 0 &&\n this.queueSizeBytes + sizeBytes > this.maxQueueSizeBytes) {\n return Promise.reject(new Error(`Queue size limit (${this.maxQueueSizeBytes} bytes) exceeded. ` +\n `Current queue size: ${this.queueSizeBytes} bytes, attempted addition: ${sizeBytes} bytes.`));\n }\n // Add to queue size tracking\n if (sizeBytes > 0) {\n this.queueSizeBytes += sizeBytes;\n }\n const onFailedResponseHook = this.onFailedResponseHook;\n let promise = this.queue.add(() => (0, index_js_1.default)(() => callable(...args).catch((error) => {\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (error instanceof Error) {\n throw error;\n }\n else {\n throw new Error(error);\n }\n }), {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n async onFailedAttempt({ error }) {\n if (error.message.startsWith(\"Cancel\") ||\n error.message.startsWith(\"TimeoutError\") ||\n error.name === \"TimeoutError\" ||\n error.message.startsWith(\"AbortError\")) {\n throw error;\n }\n if (error?.code === \"ECONNABORTED\") {\n throw error;\n }\n const response = error?.response;\n if (onFailedResponseHook) {\n const handled = await onFailedResponseHook(response);\n if (handled) {\n return;\n }\n }\n const status = response?.status ?? error?.status;\n if (status) {\n if (!STATUS_RETRYABLE.includes(+status)) {\n throw error;\n }\n }\n },\n retries: this.maxRetries,\n randomize: true,\n }), { throwOnTimeout: true });\n // Decrement queue size when the call completes (success or failure)\n if (sizeBytes > 0) {\n promise = promise.finally(() => {\n this.queueSizeBytes -= sizeBytes;\n });\n }\n // Handle signal cancellation\n if (options.signal) {\n return Promise.race([\n promise,\n new Promise((_, reject) => {\n options.signal?.addEventListener(\"abort\", () => {\n reject(new Error(\"AbortError\"));\n });\n }),\n ]);\n }\n return promise;\n }\n}\nexports.AsyncCaller = AsyncCaller;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isLangChainMessage = isLangChainMessage;\nexports.convertLangChainMessageToExample = convertLangChainMessageToExample;\nfunction isLangChainMessage(\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nmessage) {\n return typeof message?._getType === \"function\";\n}\nfunction convertLangChainMessageToExample(message) {\n const converted = {\n type: message._getType(),\n data: { content: message.content },\n };\n // Check for presence of keys in additional_kwargs\n if (message?.additional_kwargs &&\n Object.keys(message.additional_kwargs).length > 0) {\n converted.data.additional_kwargs = { ...message.additional_kwargs };\n }\n return converted;\n}\n","'use strict'\n\n// Note: this is the semver.org version of the spec that it implements\n// Not necessarily the package version of this code.\nconst SEMVER_SPEC_VERSION = '2.0.0'\n\nconst MAX_LENGTH = 256\nconst MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER ||\n/* istanbul ignore next */ 9007199254740991\n\n// Max safe segment length for coercion.\nconst MAX_SAFE_COMPONENT_LENGTH = 16\n\n// Max safe length for a build identifier. The max length minus 6 characters for\n// the shortest version with a build 0.0.0+BUILD.\nconst MAX_SAFE_BUILD_LENGTH = MAX_LENGTH - 6\n\nconst RELEASE_TYPES = [\n 'major',\n 'premajor',\n 'minor',\n 'preminor',\n 'patch',\n 'prepatch',\n 'prerelease',\n]\n\nmodule.exports = {\n MAX_LENGTH,\n MAX_SAFE_COMPONENT_LENGTH,\n MAX_SAFE_BUILD_LENGTH,\n MAX_SAFE_INTEGER,\n RELEASE_TYPES,\n SEMVER_SPEC_VERSION,\n FLAG_INCLUDE_PRERELEASE: 0b001,\n FLAG_LOOSE: 0b010,\n}\n","'use strict'\n\nconst debug = (\n typeof process === 'object' &&\n process.env &&\n process.env.NODE_DEBUG &&\n /\\bsemver\\b/i.test(process.env.NODE_DEBUG)\n) ? (...args) => console.error('SEMVER', ...args)\n : () => {}\n\nmodule.exports = debug\n","'use strict'\n\nconst {\n MAX_SAFE_COMPONENT_LENGTH,\n MAX_SAFE_BUILD_LENGTH,\n MAX_LENGTH,\n} = require('./constants')\nconst debug = require('./debug')\nexports = module.exports = {}\n\n// The actual regexps go on exports.re\nconst re = exports.re = []\nconst safeRe = exports.safeRe = []\nconst src = exports.src = []\nconst safeSrc = exports.safeSrc = []\nconst t = exports.t = {}\nlet R = 0\n\nconst LETTERDASHNUMBER = '[a-zA-Z0-9-]'\n\n// Replace some greedy regex tokens to prevent regex dos issues. These regex are\n// used internally via the safeRe object since all inputs in this library get\n// normalized first to trim and collapse all extra whitespace. The original\n// regexes are exported for userland consumption and lower level usage. A\n// future breaking change could export the safer regex only with a note that\n// all input should have extra whitespace removed.\nconst safeRegexReplacements = [\n ['\\\\s', 1],\n ['\\\\d', MAX_LENGTH],\n [LETTERDASHNUMBER, MAX_SAFE_BUILD_LENGTH],\n]\n\nconst makeSafeRegex = (value) => {\n for (const [token, max] of safeRegexReplacements) {\n value = value\n .split(`${token}*`).join(`${token}{0,${max}}`)\n .split(`${token}+`).join(`${token}{1,${max}}`)\n }\n return value\n}\n\nconst createToken = (name, value, isGlobal) => {\n const safe = makeSafeRegex(value)\n const index = R++\n debug(name, index, value)\n t[name] = index\n src[index] = value\n safeSrc[index] = safe\n re[index] = new RegExp(value, isGlobal ? 'g' : undefined)\n safeRe[index] = new RegExp(safe, isGlobal ? 'g' : undefined)\n}\n\n// The following Regular Expressions can be used for tokenizing,\n// validating, and parsing SemVer version strings.\n\n// ## Numeric Identifier\n// A single `0`, or a non-zero digit followed by zero or more digits.\n\ncreateToken('NUMERICIDENTIFIER', '0|[1-9]\\\\d*')\ncreateToken('NUMERICIDENTIFIERLOOSE', '\\\\d+')\n\n// ## Non-numeric Identifier\n// Zero or more digits, followed by a letter or hyphen, and then zero or\n// more letters, digits, or hyphens.\n\ncreateToken('NONNUMERICIDENTIFIER', `\\\\d*[a-zA-Z-]${LETTERDASHNUMBER}*`)\n\n// ## Main Version\n// Three dot-separated numeric identifiers.\n\ncreateToken('MAINVERSION', `(${src[t.NUMERICIDENTIFIER]})\\\\.` +\n `(${src[t.NUMERICIDENTIFIER]})\\\\.` +\n `(${src[t.NUMERICIDENTIFIER]})`)\n\ncreateToken('MAINVERSIONLOOSE', `(${src[t.NUMERICIDENTIFIERLOOSE]})\\\\.` +\n `(${src[t.NUMERICIDENTIFIERLOOSE]})\\\\.` +\n `(${src[t.NUMERICIDENTIFIERLOOSE]})`)\n\n// ## Pre-release Version Identifier\n// A numeric identifier, or a non-numeric identifier.\n// Non-numberic identifiers include numberic identifiers but can be longer.\n// Therefore non-numberic identifiers must go first.\n\ncreateToken('PRERELEASEIDENTIFIER', `(?:${src[t.NONNUMERICIDENTIFIER]\n}|${src[t.NUMERICIDENTIFIER]})`)\n\ncreateToken('PRERELEASEIDENTIFIERLOOSE', `(?:${src[t.NONNUMERICIDENTIFIER]\n}|${src[t.NUMERICIDENTIFIERLOOSE]})`)\n\n// ## Pre-release Version\n// Hyphen, followed by one or more dot-separated pre-release version\n// identifiers.\n\ncreateToken('PRERELEASE', `(?:-(${src[t.PRERELEASEIDENTIFIER]\n}(?:\\\\.${src[t.PRERELEASEIDENTIFIER]})*))`)\n\ncreateToken('PRERELEASELOOSE', `(?:-?(${src[t.PRERELEASEIDENTIFIERLOOSE]\n}(?:\\\\.${src[t.PRERELEASEIDENTIFIERLOOSE]})*))`)\n\n// ## Build Metadata Identifier\n// Any combination of digits, letters, or hyphens.\n\ncreateToken('BUILDIDENTIFIER', `${LETTERDASHNUMBER}+`)\n\n// ## Build Metadata\n// Plus sign, followed by one or more period-separated build metadata\n// identifiers.\n\ncreateToken('BUILD', `(?:\\\\+(${src[t.BUILDIDENTIFIER]\n}(?:\\\\.${src[t.BUILDIDENTIFIER]})*))`)\n\n// ## Full Version String\n// A main version, followed optionally by a pre-release version and\n// build metadata.\n\n// Note that the only major, minor, patch, and pre-release sections of\n// the version string are capturing groups. The build metadata is not a\n// capturing group, because it should not ever be used in version\n// comparison.\n\ncreateToken('FULLPLAIN', `v?${src[t.MAINVERSION]\n}${src[t.PRERELEASE]}?${\n src[t.BUILD]}?`)\n\ncreateToken('FULL', `^${src[t.FULLPLAIN]}$`)\n\n// like full, but allows v1.2.3 and =1.2.3, which people do sometimes.\n// also, 1.0.0alpha1 (prerelease without the hyphen) which is pretty\n// common in the npm registry.\ncreateToken('LOOSEPLAIN', `[v=\\\\s]*${src[t.MAINVERSIONLOOSE]\n}${src[t.PRERELEASELOOSE]}?${\n src[t.BUILD]}?`)\n\ncreateToken('LOOSE', `^${src[t.LOOSEPLAIN]}$`)\n\ncreateToken('GTLT', '((?:<|>)?=?)')\n\n// Something like \"2.*\" or \"1.2.x\".\n// Note that \"x.x\" is a valid xRange identifer, meaning \"any version\"\n// Only the first item is strictly required.\ncreateToken('XRANGEIDENTIFIERLOOSE', `${src[t.NUMERICIDENTIFIERLOOSE]}|x|X|\\\\*`)\ncreateToken('XRANGEIDENTIFIER', `${src[t.NUMERICIDENTIFIER]}|x|X|\\\\*`)\n\ncreateToken('XRANGEPLAIN', `[v=\\\\s]*(${src[t.XRANGEIDENTIFIER]})` +\n `(?:\\\\.(${src[t.XRANGEIDENTIFIER]})` +\n `(?:\\\\.(${src[t.XRANGEIDENTIFIER]})` +\n `(?:${src[t.PRERELEASE]})?${\n src[t.BUILD]}?` +\n `)?)?`)\n\ncreateToken('XRANGEPLAINLOOSE', `[v=\\\\s]*(${src[t.XRANGEIDENTIFIERLOOSE]})` +\n `(?:\\\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` +\n `(?:\\\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` +\n `(?:${src[t.PRERELEASELOOSE]})?${\n src[t.BUILD]}?` +\n `)?)?`)\n\ncreateToken('XRANGE', `^${src[t.GTLT]}\\\\s*${src[t.XRANGEPLAIN]}$`)\ncreateToken('XRANGELOOSE', `^${src[t.GTLT]}\\\\s*${src[t.XRANGEPLAINLOOSE]}$`)\n\n// Coercion.\n// Extract anything that could conceivably be a part of a valid semver\ncreateToken('COERCEPLAIN', `${'(^|[^\\\\d])' +\n '(\\\\d{1,'}${MAX_SAFE_COMPONENT_LENGTH}})` +\n `(?:\\\\.(\\\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` +\n `(?:\\\\.(\\\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?`)\ncreateToken('COERCE', `${src[t.COERCEPLAIN]}(?:$|[^\\\\d])`)\ncreateToken('COERCEFULL', src[t.COERCEPLAIN] +\n `(?:${src[t.PRERELEASE]})?` +\n `(?:${src[t.BUILD]})?` +\n `(?:$|[^\\\\d])`)\ncreateToken('COERCERTL', src[t.COERCE], true)\ncreateToken('COERCERTLFULL', src[t.COERCEFULL], true)\n\n// Tilde ranges.\n// Meaning is \"reasonably at or greater than\"\ncreateToken('LONETILDE', '(?:~>?)')\n\ncreateToken('TILDETRIM', `(\\\\s*)${src[t.LONETILDE]}\\\\s+`, true)\nexports.tildeTrimReplace = '$1~'\n\ncreateToken('TILDE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAIN]}$`)\ncreateToken('TILDELOOSE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAINLOOSE]}$`)\n\n// Caret ranges.\n// Meaning is \"at least and backwards compatible with\"\ncreateToken('LONECARET', '(?:\\\\^)')\n\ncreateToken('CARETTRIM', `(\\\\s*)${src[t.LONECARET]}\\\\s+`, true)\nexports.caretTrimReplace = '$1^'\n\ncreateToken('CARET', `^${src[t.LONECARET]}${src[t.XRANGEPLAIN]}$`)\ncreateToken('CARETLOOSE', `^${src[t.LONECARET]}${src[t.XRANGEPLAINLOOSE]}$`)\n\n// A simple gt/lt/eq thing, or just \"\" to indicate \"any version\"\ncreateToken('COMPARATORLOOSE', `^${src[t.GTLT]}\\\\s*(${src[t.LOOSEPLAIN]})$|^$`)\ncreateToken('COMPARATOR', `^${src[t.GTLT]}\\\\s*(${src[t.FULLPLAIN]})$|^$`)\n\n// An expression to strip any whitespace between the gtlt and the thing\n// it modifies, so that `> 1.2.3` ==> `>1.2.3`\ncreateToken('COMPARATORTRIM', `(\\\\s*)${src[t.GTLT]\n}\\\\s*(${src[t.LOOSEPLAIN]}|${src[t.XRANGEPLAIN]})`, true)\nexports.comparatorTrimReplace = '$1$2$3'\n\n// Something like `1.2.3 - 1.2.4`\n// Note that these all use the loose form, because they'll be\n// checked against either the strict or loose comparator form\n// later.\ncreateToken('HYPHENRANGE', `^\\\\s*(${src[t.XRANGEPLAIN]})` +\n `\\\\s+-\\\\s+` +\n `(${src[t.XRANGEPLAIN]})` +\n `\\\\s*$`)\n\ncreateToken('HYPHENRANGELOOSE', `^\\\\s*(${src[t.XRANGEPLAINLOOSE]})` +\n `\\\\s+-\\\\s+` +\n `(${src[t.XRANGEPLAINLOOSE]})` +\n `\\\\s*$`)\n\n// Star ranges basically just allow anything at all.\ncreateToken('STAR', '(<|>)?=?\\\\s*\\\\*')\n// >=0.0.0 is like a star\ncreateToken('GTE0', '^\\\\s*>=\\\\s*0\\\\.0\\\\.0\\\\s*$')\ncreateToken('GTE0PRE', '^\\\\s*>=\\\\s*0\\\\.0\\\\.0-0\\\\s*$')\n","'use strict'\n\n// parse out just the options we care about\nconst looseOption = Object.freeze({ loose: true })\nconst emptyOpts = Object.freeze({ })\nconst parseOptions = options => {\n if (!options) {\n return emptyOpts\n }\n\n if (typeof options !== 'object') {\n return looseOption\n }\n\n return options\n}\nmodule.exports = parseOptions\n","'use strict'\n\nconst numeric = /^[0-9]+$/\nconst compareIdentifiers = (a, b) => {\n if (typeof a === 'number' && typeof b === 'number') {\n return a === b ? 0 : a < b ? -1 : 1\n }\n\n const anum = numeric.test(a)\n const bnum = numeric.test(b)\n\n if (anum && bnum) {\n a = +a\n b = +b\n }\n\n return a === b ? 0\n : (anum && !bnum) ? -1\n : (bnum && !anum) ? 1\n : a < b ? -1\n : 1\n}\n\nconst rcompareIdentifiers = (a, b) => compareIdentifiers(b, a)\n\nmodule.exports = {\n compareIdentifiers,\n rcompareIdentifiers,\n}\n","'use strict'\n\nconst debug = require('../internal/debug')\nconst { MAX_LENGTH, MAX_SAFE_INTEGER } = require('../internal/constants')\nconst { safeRe: re, t } = require('../internal/re')\n\nconst parseOptions = require('../internal/parse-options')\nconst { compareIdentifiers } = require('../internal/identifiers')\nclass SemVer {\n constructor (version, options) {\n options = parseOptions(options)\n\n if (version instanceof SemVer) {\n if (version.loose === !!options.loose &&\n version.includePrerelease === !!options.includePrerelease) {\n return version\n } else {\n version = version.version\n }\n } else if (typeof version !== 'string') {\n throw new TypeError(`Invalid version. Must be a string. Got type \"${typeof version}\".`)\n }\n\n if (version.length > MAX_LENGTH) {\n throw new TypeError(\n `version is longer than ${MAX_LENGTH} characters`\n )\n }\n\n debug('SemVer', version, options)\n this.options = options\n this.loose = !!options.loose\n // this isn't actually relevant for versions, but keep it so that we\n // don't run into trouble passing this.options around.\n this.includePrerelease = !!options.includePrerelease\n\n const m = version.trim().match(options.loose ? re[t.LOOSE] : re[t.FULL])\n\n if (!m) {\n throw new TypeError(`Invalid Version: ${version}`)\n }\n\n this.raw = version\n\n // these are actually numbers\n this.major = +m[1]\n this.minor = +m[2]\n this.patch = +m[3]\n\n if (this.major > MAX_SAFE_INTEGER || this.major < 0) {\n throw new TypeError('Invalid major version')\n }\n\n if (this.minor > MAX_SAFE_INTEGER || this.minor < 0) {\n throw new TypeError('Invalid minor version')\n }\n\n if (this.patch > MAX_SAFE_INTEGER || this.patch < 0) {\n throw new TypeError('Invalid patch version')\n }\n\n // numberify any prerelease numeric ids\n if (!m[4]) {\n this.prerelease = []\n } else {\n this.prerelease = m[4].split('.').map((id) => {\n if (/^[0-9]+$/.test(id)) {\n const num = +id\n if (num >= 0 && num < MAX_SAFE_INTEGER) {\n return num\n }\n }\n return id\n })\n }\n\n this.build = m[5] ? m[5].split('.') : []\n this.format()\n }\n\n format () {\n this.version = `${this.major}.${this.minor}.${this.patch}`\n if (this.prerelease.length) {\n this.version += `-${this.prerelease.join('.')}`\n }\n return this.version\n }\n\n toString () {\n return this.version\n }\n\n compare (other) {\n debug('SemVer.compare', this.version, this.options, other)\n if (!(other instanceof SemVer)) {\n if (typeof other === 'string' && other === this.version) {\n return 0\n }\n other = new SemVer(other, this.options)\n }\n\n if (other.version === this.version) {\n return 0\n }\n\n return this.compareMain(other) || this.comparePre(other)\n }\n\n compareMain (other) {\n if (!(other instanceof SemVer)) {\n other = new SemVer(other, this.options)\n }\n\n if (this.major < other.major) {\n return -1\n }\n if (this.major > other.major) {\n return 1\n }\n if (this.minor < other.minor) {\n return -1\n }\n if (this.minor > other.minor) {\n return 1\n }\n if (this.patch < other.patch) {\n return -1\n }\n if (this.patch > other.patch) {\n return 1\n }\n return 0\n }\n\n comparePre (other) {\n if (!(other instanceof SemVer)) {\n other = new SemVer(other, this.options)\n }\n\n // NOT having a prerelease is > having one\n if (this.prerelease.length && !other.prerelease.length) {\n return -1\n } else if (!this.prerelease.length && other.prerelease.length) {\n return 1\n } else if (!this.prerelease.length && !other.prerelease.length) {\n return 0\n }\n\n let i = 0\n do {\n const a = this.prerelease[i]\n const b = other.prerelease[i]\n debug('prerelease compare', i, a, b)\n if (a === undefined && b === undefined) {\n return 0\n } else if (b === undefined) {\n return 1\n } else if (a === undefined) {\n return -1\n } else if (a === b) {\n continue\n } else {\n return compareIdentifiers(a, b)\n }\n } while (++i)\n }\n\n compareBuild (other) {\n if (!(other instanceof SemVer)) {\n other = new SemVer(other, this.options)\n }\n\n let i = 0\n do {\n const a = this.build[i]\n const b = other.build[i]\n debug('build compare', i, a, b)\n if (a === undefined && b === undefined) {\n return 0\n } else if (b === undefined) {\n return 1\n } else if (a === undefined) {\n return -1\n } else if (a === b) {\n continue\n } else {\n return compareIdentifiers(a, b)\n }\n } while (++i)\n }\n\n // preminor will bump the version up to the next minor release, and immediately\n // down to pre-release. premajor and prepatch work the same way.\n inc (release, identifier, identifierBase) {\n if (release.startsWith('pre')) {\n if (!identifier && identifierBase === false) {\n throw new Error('invalid increment argument: identifier is empty')\n }\n // Avoid an invalid semver results\n if (identifier) {\n const match = `-${identifier}`.match(this.options.loose ? re[t.PRERELEASELOOSE] : re[t.PRERELEASE])\n if (!match || match[1] !== identifier) {\n throw new Error(`invalid identifier: ${identifier}`)\n }\n }\n }\n\n switch (release) {\n case 'premajor':\n this.prerelease.length = 0\n this.patch = 0\n this.minor = 0\n this.major++\n this.inc('pre', identifier, identifierBase)\n break\n case 'preminor':\n this.prerelease.length = 0\n this.patch = 0\n this.minor++\n this.inc('pre', identifier, identifierBase)\n break\n case 'prepatch':\n // If this is already a prerelease, it will bump to the next version\n // drop any prereleases that might already exist, since they are not\n // relevant at this point.\n this.prerelease.length = 0\n this.inc('patch', identifier, identifierBase)\n this.inc('pre', identifier, identifierBase)\n break\n // If the input is a non-prerelease version, this acts the same as\n // prepatch.\n case 'prerelease':\n if (this.prerelease.length === 0) {\n this.inc('patch', identifier, identifierBase)\n }\n this.inc('pre', identifier, identifierBase)\n break\n case 'release':\n if (this.prerelease.length === 0) {\n throw new Error(`version ${this.raw} is not a prerelease`)\n }\n this.prerelease.length = 0\n break\n\n case 'major':\n // If this is a pre-major version, bump up to the same major version.\n // Otherwise increment major.\n // 1.0.0-5 bumps to 1.0.0\n // 1.1.0 bumps to 2.0.0\n if (\n this.minor !== 0 ||\n this.patch !== 0 ||\n this.prerelease.length === 0\n ) {\n this.major++\n }\n this.minor = 0\n this.patch = 0\n this.prerelease = []\n break\n case 'minor':\n // If this is a pre-minor version, bump up to the same minor version.\n // Otherwise increment minor.\n // 1.2.0-5 bumps to 1.2.0\n // 1.2.1 bumps to 1.3.0\n if (this.patch !== 0 || this.prerelease.length === 0) {\n this.minor++\n }\n this.patch = 0\n this.prerelease = []\n break\n case 'patch':\n // If this is not a pre-release version, it will increment the patch.\n // If it is a pre-release it will bump up to the same patch version.\n // 1.2.0-5 patches to 1.2.0\n // 1.2.0 patches to 1.2.1\n if (this.prerelease.length === 0) {\n this.patch++\n }\n this.prerelease = []\n break\n // This probably shouldn't be used publicly.\n // 1.0.0 'pre' would become 1.0.0-0 which is the wrong direction.\n case 'pre': {\n const base = Number(identifierBase) ? 1 : 0\n\n if (this.prerelease.length === 0) {\n this.prerelease = [base]\n } else {\n let i = this.prerelease.length\n while (--i >= 0) {\n if (typeof this.prerelease[i] === 'number') {\n this.prerelease[i]++\n i = -2\n }\n }\n if (i === -1) {\n // didn't increment anything\n if (identifier === this.prerelease.join('.') && identifierBase === false) {\n throw new Error('invalid increment argument: identifier already exists')\n }\n this.prerelease.push(base)\n }\n }\n if (identifier) {\n // 1.2.0-beta.1 bumps to 1.2.0-beta.2,\n // 1.2.0-beta.fooblz or 1.2.0-beta bumps to 1.2.0-beta.0\n let prerelease = [identifier, base]\n if (identifierBase === false) {\n prerelease = [identifier]\n }\n if (compareIdentifiers(this.prerelease[0], identifier) === 0) {\n if (isNaN(this.prerelease[1])) {\n this.prerelease = prerelease\n }\n } else {\n this.prerelease = prerelease\n }\n }\n break\n }\n default:\n throw new Error(`invalid increment argument: ${release}`)\n }\n this.raw = this.format()\n if (this.build.length) {\n this.raw += `+${this.build.join('.')}`\n }\n return this\n }\n}\n\nmodule.exports = SemVer\n","'use strict'\n\nconst SemVer = require('../classes/semver')\nconst parse = (version, options, throwErrors = false) => {\n if (version instanceof SemVer) {\n return version\n }\n try {\n return new SemVer(version, options)\n } catch (er) {\n if (!throwErrors) {\n return null\n }\n throw er\n }\n}\n\nmodule.exports = parse\n","'use strict'\n\nconst parse = require('./parse')\nconst valid = (version, options) => {\n const v = parse(version, options)\n return v ? v.version : null\n}\nmodule.exports = valid\n","'use strict'\n\nconst parse = require('./parse')\nconst clean = (version, options) => {\n const s = parse(version.trim().replace(/^[=v]+/, ''), options)\n return s ? s.version : null\n}\nmodule.exports = clean\n","'use strict'\n\nconst SemVer = require('../classes/semver')\n\nconst inc = (version, release, options, identifier, identifierBase) => {\n if (typeof (options) === 'string') {\n identifierBase = identifier\n identifier = options\n options = undefined\n }\n\n try {\n return new SemVer(\n version instanceof SemVer ? version.version : version,\n options\n ).inc(release, identifier, identifierBase).version\n } catch (er) {\n return null\n }\n}\nmodule.exports = inc\n","'use strict'\n\nconst parse = require('./parse.js')\n\nconst diff = (version1, version2) => {\n const v1 = parse(version1, null, true)\n const v2 = parse(version2, null, true)\n const comparison = v1.compare(v2)\n\n if (comparison === 0) {\n return null\n }\n\n const v1Higher = comparison > 0\n const highVersion = v1Higher ? v1 : v2\n const lowVersion = v1Higher ? v2 : v1\n const highHasPre = !!highVersion.prerelease.length\n const lowHasPre = !!lowVersion.prerelease.length\n\n if (lowHasPre && !highHasPre) {\n // Going from prerelease -> no prerelease requires some special casing\n\n // If the low version has only a major, then it will always be a major\n // Some examples:\n // 1.0.0-1 -> 1.0.0\n // 1.0.0-1 -> 1.1.1\n // 1.0.0-1 -> 2.0.0\n if (!lowVersion.patch && !lowVersion.minor) {\n return 'major'\n }\n\n // If the main part has no difference\n if (lowVersion.compareMain(highVersion) === 0) {\n if (lowVersion.minor && !lowVersion.patch) {\n return 'minor'\n }\n return 'patch'\n }\n }\n\n // add the `pre` prefix if we are going to a prerelease version\n const prefix = highHasPre ? 'pre' : ''\n\n if (v1.major !== v2.major) {\n return prefix + 'major'\n }\n\n if (v1.minor !== v2.minor) {\n return prefix + 'minor'\n }\n\n if (v1.patch !== v2.patch) {\n return prefix + 'patch'\n }\n\n // high and low are preleases\n return 'prerelease'\n}\n\nmodule.exports = diff\n","'use strict'\n\nconst SemVer = require('../classes/semver')\nconst major = (a, loose) => new SemVer(a, loose).major\nmodule.exports = major\n","'use strict'\n\nconst SemVer = require('../classes/semver')\nconst minor = (a, loose) => new SemVer(a, loose).minor\nmodule.exports = minor\n","'use strict'\n\nconst SemVer = require('../classes/semver')\nconst patch = (a, loose) => new SemVer(a, loose).patch\nmodule.exports = patch\n","'use strict'\n\nconst parse = require('./parse')\nconst prerelease = (version, options) => {\n const parsed = parse(version, options)\n return (parsed && parsed.prerelease.length) ? parsed.prerelease : null\n}\nmodule.exports = prerelease\n","'use strict'\n\nconst SemVer = require('../classes/semver')\nconst compare = (a, b, loose) =>\n new SemVer(a, loose).compare(new SemVer(b, loose))\n\nmodule.exports = compare\n","'use strict'\n\nconst compare = require('./compare')\nconst rcompare = (a, b, loose) => compare(b, a, loose)\nmodule.exports = rcompare\n","'use strict'\n\nconst compare = require('./compare')\nconst compareLoose = (a, b) => compare(a, b, true)\nmodule.exports = compareLoose\n","'use strict'\n\nconst SemVer = require('../classes/semver')\nconst compareBuild = (a, b, loose) => {\n const versionA = new SemVer(a, loose)\n const versionB = new SemVer(b, loose)\n return versionA.compare(versionB) || versionA.compareBuild(versionB)\n}\nmodule.exports = compareBuild\n","'use strict'\n\nconst compareBuild = require('./compare-build')\nconst sort = (list, loose) => list.sort((a, b) => compareBuild(a, b, loose))\nmodule.exports = sort\n","'use strict'\n\nconst compareBuild = require('./compare-build')\nconst rsort = (list, loose) => list.sort((a, b) => compareBuild(b, a, loose))\nmodule.exports = rsort\n","'use strict'\n\nconst compare = require('./compare')\nconst gt = (a, b, loose) => compare(a, b, loose) > 0\nmodule.exports = gt\n","'use strict'\n\nconst compare = require('./compare')\nconst lt = (a, b, loose) => compare(a, b, loose) < 0\nmodule.exports = lt\n","'use strict'\n\nconst compare = require('./compare')\nconst eq = (a, b, loose) => compare(a, b, loose) === 0\nmodule.exports = eq\n","'use strict'\n\nconst compare = require('./compare')\nconst neq = (a, b, loose) => compare(a, b, loose) !== 0\nmodule.exports = neq\n","'use strict'\n\nconst compare = require('./compare')\nconst gte = (a, b, loose) => compare(a, b, loose) >= 0\nmodule.exports = gte\n","'use strict'\n\nconst compare = require('./compare')\nconst lte = (a, b, loose) => compare(a, b, loose) <= 0\nmodule.exports = lte\n","'use strict'\n\nconst eq = require('./eq')\nconst neq = require('./neq')\nconst gt = require('./gt')\nconst gte = require('./gte')\nconst lt = require('./lt')\nconst lte = require('./lte')\n\nconst cmp = (a, op, b, loose) => {\n switch (op) {\n case '===':\n if (typeof a === 'object') {\n a = a.version\n }\n if (typeof b === 'object') {\n b = b.version\n }\n return a === b\n\n case '!==':\n if (typeof a === 'object') {\n a = a.version\n }\n if (typeof b === 'object') {\n b = b.version\n }\n return a !== b\n\n case '':\n case '=':\n case '==':\n return eq(a, b, loose)\n\n case '!=':\n return neq(a, b, loose)\n\n case '>':\n return gt(a, b, loose)\n\n case '>=':\n return gte(a, b, loose)\n\n case '<':\n return lt(a, b, loose)\n\n case '<=':\n return lte(a, b, loose)\n\n default:\n throw new TypeError(`Invalid operator: ${op}`)\n }\n}\nmodule.exports = cmp\n","'use strict'\n\nconst SemVer = require('../classes/semver')\nconst parse = require('./parse')\nconst { safeRe: re, t } = require('../internal/re')\n\nconst coerce = (version, options) => {\n if (version instanceof SemVer) {\n return version\n }\n\n if (typeof version === 'number') {\n version = String(version)\n }\n\n if (typeof version !== 'string') {\n return null\n }\n\n options = options || {}\n\n let match = null\n if (!options.rtl) {\n match = version.match(options.includePrerelease ? re[t.COERCEFULL] : re[t.COERCE])\n } else {\n // Find the right-most coercible string that does not share\n // a terminus with a more left-ward coercible string.\n // Eg, '1.2.3.4' wants to coerce '2.3.4', not '3.4' or '4'\n // With includePrerelease option set, '1.2.3.4-rc' wants to coerce '2.3.4-rc', not '2.3.4'\n //\n // Walk through the string checking with a /g regexp\n // Manually set the index so as to pick up overlapping matches.\n // Stop when we get a match that ends at the string end, since no\n // coercible string can be more right-ward without the same terminus.\n const coerceRtlRegex = options.includePrerelease ? re[t.COERCERTLFULL] : re[t.COERCERTL]\n let next\n while ((next = coerceRtlRegex.exec(version)) &&\n (!match || match.index + match[0].length !== version.length)\n ) {\n if (!match ||\n next.index + next[0].length !== match.index + match[0].length) {\n match = next\n }\n coerceRtlRegex.lastIndex = next.index + next[1].length + next[2].length\n }\n // leave it in a clean state\n coerceRtlRegex.lastIndex = -1\n }\n\n if (match === null) {\n return null\n }\n\n const major = match[2]\n const minor = match[3] || '0'\n const patch = match[4] || '0'\n const prerelease = options.includePrerelease && match[5] ? `-${match[5]}` : ''\n const build = options.includePrerelease && match[6] ? `+${match[6]}` : ''\n\n return parse(`${major}.${minor}.${patch}${prerelease}${build}`, options)\n}\nmodule.exports = coerce\n","'use strict'\n\nclass LRUCache {\n constructor () {\n this.max = 1000\n this.map = new Map()\n }\n\n get (key) {\n const value = this.map.get(key)\n if (value === undefined) {\n return undefined\n } else {\n // Remove the key from the map and add it to the end\n this.map.delete(key)\n this.map.set(key, value)\n return value\n }\n }\n\n delete (key) {\n return this.map.delete(key)\n }\n\n set (key, value) {\n const deleted = this.delete(key)\n\n if (!deleted && value !== undefined) {\n // If cache is full, delete the least recently used item\n if (this.map.size >= this.max) {\n const firstKey = this.map.keys().next().value\n this.delete(firstKey)\n }\n\n this.map.set(key, value)\n }\n\n return this\n }\n}\n\nmodule.exports = LRUCache\n","'use strict'\n\nconst SPACE_CHARACTERS = /\\s+/g\n\n// hoisted class for cyclic dependency\nclass Range {\n constructor (range, options) {\n options = parseOptions(options)\n\n if (range instanceof Range) {\n if (\n range.loose === !!options.loose &&\n range.includePrerelease === !!options.includePrerelease\n ) {\n return range\n } else {\n return new Range(range.raw, options)\n }\n }\n\n if (range instanceof Comparator) {\n // just put it in the set and return\n this.raw = range.value\n this.set = [[range]]\n this.formatted = undefined\n return this\n }\n\n this.options = options\n this.loose = !!options.loose\n this.includePrerelease = !!options.includePrerelease\n\n // First reduce all whitespace as much as possible so we do not have to rely\n // on potentially slow regexes like \\s*. This is then stored and used for\n // future error messages as well.\n this.raw = range.trim().replace(SPACE_CHARACTERS, ' ')\n\n // First, split on ||\n this.set = this.raw\n .split('||')\n // map the range to a 2d array of comparators\n .map(r => this.parseRange(r.trim()))\n // throw out any comparator lists that are empty\n // this generally means that it was not a valid range, which is allowed\n // in loose mode, but will still throw if the WHOLE range is invalid.\n .filter(c => c.length)\n\n if (!this.set.length) {\n throw new TypeError(`Invalid SemVer Range: ${this.raw}`)\n }\n\n // if we have any that are not the null set, throw out null sets.\n if (this.set.length > 1) {\n // keep the first one, in case they're all null sets\n const first = this.set[0]\n this.set = this.set.filter(c => !isNullSet(c[0]))\n if (this.set.length === 0) {\n this.set = [first]\n } else if (this.set.length > 1) {\n // if we have any that are *, then the range is just *\n for (const c of this.set) {\n if (c.length === 1 && isAny(c[0])) {\n this.set = [c]\n break\n }\n }\n }\n }\n\n this.formatted = undefined\n }\n\n get range () {\n if (this.formatted === undefined) {\n this.formatted = ''\n for (let i = 0; i < this.set.length; i++) {\n if (i > 0) {\n this.formatted += '||'\n }\n const comps = this.set[i]\n for (let k = 0; k < comps.length; k++) {\n if (k > 0) {\n this.formatted += ' '\n }\n this.formatted += comps[k].toString().trim()\n }\n }\n }\n return this.formatted\n }\n\n format () {\n return this.range\n }\n\n toString () {\n return this.range\n }\n\n parseRange (range) {\n // memoize range parsing for performance.\n // this is a very hot path, and fully deterministic.\n const memoOpts =\n (this.options.includePrerelease && FLAG_INCLUDE_PRERELEASE) |\n (this.options.loose && FLAG_LOOSE)\n const memoKey = memoOpts + ':' + range\n const cached = cache.get(memoKey)\n if (cached) {\n return cached\n }\n\n const loose = this.options.loose\n // `1.2.3 - 1.2.4` => `>=1.2.3 <=1.2.4`\n const hr = loose ? re[t.HYPHENRANGELOOSE] : re[t.HYPHENRANGE]\n range = range.replace(hr, hyphenReplace(this.options.includePrerelease))\n debug('hyphen replace', range)\n\n // `> 1.2.3 < 1.2.5` => `>1.2.3 <1.2.5`\n range = range.replace(re[t.COMPARATORTRIM], comparatorTrimReplace)\n debug('comparator trim', range)\n\n // `~ 1.2.3` => `~1.2.3`\n range = range.replace(re[t.TILDETRIM], tildeTrimReplace)\n debug('tilde trim', range)\n\n // `^ 1.2.3` => `^1.2.3`\n range = range.replace(re[t.CARETTRIM], caretTrimReplace)\n debug('caret trim', range)\n\n // At this point, the range is completely trimmed and\n // ready to be split into comparators.\n\n let rangeList = range\n .split(' ')\n .map(comp => parseComparator(comp, this.options))\n .join(' ')\n .split(/\\s+/)\n // >=0.0.0 is equivalent to *\n .map(comp => replaceGTE0(comp, this.options))\n\n if (loose) {\n // in loose mode, throw out any that are not valid comparators\n rangeList = rangeList.filter(comp => {\n debug('loose invalid filter', comp, this.options)\n return !!comp.match(re[t.COMPARATORLOOSE])\n })\n }\n debug('range list', rangeList)\n\n // if any comparators are the null set, then replace with JUST null set\n // if more than one comparator, remove any * comparators\n // also, don't include the same comparator more than once\n const rangeMap = new Map()\n const comparators = rangeList.map(comp => new Comparator(comp, this.options))\n for (const comp of comparators) {\n if (isNullSet(comp)) {\n return [comp]\n }\n rangeMap.set(comp.value, comp)\n }\n if (rangeMap.size > 1 && rangeMap.has('')) {\n rangeMap.delete('')\n }\n\n const result = [...rangeMap.values()]\n cache.set(memoKey, result)\n return result\n }\n\n intersects (range, options) {\n if (!(range instanceof Range)) {\n throw new TypeError('a Range is required')\n }\n\n return this.set.some((thisComparators) => {\n return (\n isSatisfiable(thisComparators, options) &&\n range.set.some((rangeComparators) => {\n return (\n isSatisfiable(rangeComparators, options) &&\n thisComparators.every((thisComparator) => {\n return rangeComparators.every((rangeComparator) => {\n return thisComparator.intersects(rangeComparator, options)\n })\n })\n )\n })\n )\n })\n }\n\n // if ANY of the sets match ALL of its comparators, then pass\n test (version) {\n if (!version) {\n return false\n }\n\n if (typeof version === 'string') {\n try {\n version = new SemVer(version, this.options)\n } catch (er) {\n return false\n }\n }\n\n for (let i = 0; i < this.set.length; i++) {\n if (testSet(this.set[i], version, this.options)) {\n return true\n }\n }\n return false\n }\n}\n\nmodule.exports = Range\n\nconst LRU = require('../internal/lrucache')\nconst cache = new LRU()\n\nconst parseOptions = require('../internal/parse-options')\nconst Comparator = require('./comparator')\nconst debug = require('../internal/debug')\nconst SemVer = require('./semver')\nconst {\n safeRe: re,\n t,\n comparatorTrimReplace,\n tildeTrimReplace,\n caretTrimReplace,\n} = require('../internal/re')\nconst { FLAG_INCLUDE_PRERELEASE, FLAG_LOOSE } = require('../internal/constants')\n\nconst isNullSet = c => c.value === '<0.0.0-0'\nconst isAny = c => c.value === ''\n\n// take a set of comparators and determine whether there\n// exists a version which can satisfy it\nconst isSatisfiable = (comparators, options) => {\n let result = true\n const remainingComparators = comparators.slice()\n let testComparator = remainingComparators.pop()\n\n while (result && remainingComparators.length) {\n result = remainingComparators.every((otherComparator) => {\n return testComparator.intersects(otherComparator, options)\n })\n\n testComparator = remainingComparators.pop()\n }\n\n return result\n}\n\n// comprised of xranges, tildes, stars, and gtlt's at this point.\n// already replaced the hyphen ranges\n// turn into a set of JUST comparators.\nconst parseComparator = (comp, options) => {\n comp = comp.replace(re[t.BUILD], '')\n debug('comp', comp, options)\n comp = replaceCarets(comp, options)\n debug('caret', comp)\n comp = replaceTildes(comp, options)\n debug('tildes', comp)\n comp = replaceXRanges(comp, options)\n debug('xrange', comp)\n comp = replaceStars(comp, options)\n debug('stars', comp)\n return comp\n}\n\nconst isX = id => !id || id.toLowerCase() === 'x' || id === '*'\n\n// ~, ~> --> * (any, kinda silly)\n// ~2, ~2.x, ~2.x.x, ~>2, ~>2.x ~>2.x.x --> >=2.0.0 <3.0.0-0\n// ~2.0, ~2.0.x, ~>2.0, ~>2.0.x --> >=2.0.0 <2.1.0-0\n// ~1.2, ~1.2.x, ~>1.2, ~>1.2.x --> >=1.2.0 <1.3.0-0\n// ~1.2.3, ~>1.2.3 --> >=1.2.3 <1.3.0-0\n// ~1.2.0, ~>1.2.0 --> >=1.2.0 <1.3.0-0\n// ~0.0.1 --> >=0.0.1 <0.1.0-0\nconst replaceTildes = (comp, options) => {\n return comp\n .trim()\n .split(/\\s+/)\n .map((c) => replaceTilde(c, options))\n .join(' ')\n}\n\nconst replaceTilde = (comp, options) => {\n const r = options.loose ? re[t.TILDELOOSE] : re[t.TILDE]\n return comp.replace(r, (_, M, m, p, pr) => {\n debug('tilde', comp, _, M, m, p, pr)\n let ret\n\n if (isX(M)) {\n ret = ''\n } else if (isX(m)) {\n ret = `>=${M}.0.0 <${+M + 1}.0.0-0`\n } else if (isX(p)) {\n // ~1.2 == >=1.2.0 <1.3.0-0\n ret = `>=${M}.${m}.0 <${M}.${+m + 1}.0-0`\n } else if (pr) {\n debug('replaceTilde pr', pr)\n ret = `>=${M}.${m}.${p}-${pr\n } <${M}.${+m + 1}.0-0`\n } else {\n // ~1.2.3 == >=1.2.3 <1.3.0-0\n ret = `>=${M}.${m}.${p\n } <${M}.${+m + 1}.0-0`\n }\n\n debug('tilde return', ret)\n return ret\n })\n}\n\n// ^ --> * (any, kinda silly)\n// ^2, ^2.x, ^2.x.x --> >=2.0.0 <3.0.0-0\n// ^2.0, ^2.0.x --> >=2.0.0 <3.0.0-0\n// ^1.2, ^1.2.x --> >=1.2.0 <2.0.0-0\n// ^1.2.3 --> >=1.2.3 <2.0.0-0\n// ^1.2.0 --> >=1.2.0 <2.0.0-0\n// ^0.0.1 --> >=0.0.1 <0.0.2-0\n// ^0.1.0 --> >=0.1.0 <0.2.0-0\nconst replaceCarets = (comp, options) => {\n return comp\n .trim()\n .split(/\\s+/)\n .map((c) => replaceCaret(c, options))\n .join(' ')\n}\n\nconst replaceCaret = (comp, options) => {\n debug('caret', comp, options)\n const r = options.loose ? re[t.CARETLOOSE] : re[t.CARET]\n const z = options.includePrerelease ? '-0' : ''\n return comp.replace(r, (_, M, m, p, pr) => {\n debug('caret', comp, _, M, m, p, pr)\n let ret\n\n if (isX(M)) {\n ret = ''\n } else if (isX(m)) {\n ret = `>=${M}.0.0${z} <${+M + 1}.0.0-0`\n } else if (isX(p)) {\n if (M === '0') {\n ret = `>=${M}.${m}.0${z} <${M}.${+m + 1}.0-0`\n } else {\n ret = `>=${M}.${m}.0${z} <${+M + 1}.0.0-0`\n }\n } else if (pr) {\n debug('replaceCaret pr', pr)\n if (M === '0') {\n if (m === '0') {\n ret = `>=${M}.${m}.${p}-${pr\n } <${M}.${m}.${+p + 1}-0`\n } else {\n ret = `>=${M}.${m}.${p}-${pr\n } <${M}.${+m + 1}.0-0`\n }\n } else {\n ret = `>=${M}.${m}.${p}-${pr\n } <${+M + 1}.0.0-0`\n }\n } else {\n debug('no pr')\n if (M === '0') {\n if (m === '0') {\n ret = `>=${M}.${m}.${p\n }${z} <${M}.${m}.${+p + 1}-0`\n } else {\n ret = `>=${M}.${m}.${p\n }${z} <${M}.${+m + 1}.0-0`\n }\n } else {\n ret = `>=${M}.${m}.${p\n } <${+M + 1}.0.0-0`\n }\n }\n\n debug('caret return', ret)\n return ret\n })\n}\n\nconst replaceXRanges = (comp, options) => {\n debug('replaceXRanges', comp, options)\n return comp\n .split(/\\s+/)\n .map((c) => replaceXRange(c, options))\n .join(' ')\n}\n\nconst replaceXRange = (comp, options) => {\n comp = comp.trim()\n const r = options.loose ? re[t.XRANGELOOSE] : re[t.XRANGE]\n return comp.replace(r, (ret, gtlt, M, m, p, pr) => {\n debug('xRange', comp, ret, gtlt, M, m, p, pr)\n const xM = isX(M)\n const xm = xM || isX(m)\n const xp = xm || isX(p)\n const anyX = xp\n\n if (gtlt === '=' && anyX) {\n gtlt = ''\n }\n\n // if we're including prereleases in the match, then we need\n // to fix this to -0, the lowest possible prerelease value\n pr = options.includePrerelease ? '-0' : ''\n\n if (xM) {\n if (gtlt === '>' || gtlt === '<') {\n // nothing is allowed\n ret = '<0.0.0-0'\n } else {\n // nothing is forbidden\n ret = '*'\n }\n } else if (gtlt && anyX) {\n // we know patch is an x, because we have any x at all.\n // replace X with 0\n if (xm) {\n m = 0\n }\n p = 0\n\n if (gtlt === '>') {\n // >1 => >=2.0.0\n // >1.2 => >=1.3.0\n gtlt = '>='\n if (xm) {\n M = +M + 1\n m = 0\n p = 0\n } else {\n m = +m + 1\n p = 0\n }\n } else if (gtlt === '<=') {\n // <=0.7.x is actually <0.8.0, since any 0.7.x should\n // pass. Similarly, <=7.x is actually <8.0.0, etc.\n gtlt = '<'\n if (xm) {\n M = +M + 1\n } else {\n m = +m + 1\n }\n }\n\n if (gtlt === '<') {\n pr = '-0'\n }\n\n ret = `${gtlt + M}.${m}.${p}${pr}`\n } else if (xm) {\n ret = `>=${M}.0.0${pr} <${+M + 1}.0.0-0`\n } else if (xp) {\n ret = `>=${M}.${m}.0${pr\n } <${M}.${+m + 1}.0-0`\n }\n\n debug('xRange return', ret)\n\n return ret\n })\n}\n\n// Because * is AND-ed with everything else in the comparator,\n// and '' means \"any version\", just remove the *s entirely.\nconst replaceStars = (comp, options) => {\n debug('replaceStars', comp, options)\n // Looseness is ignored here. star is always as loose as it gets!\n return comp\n .trim()\n .replace(re[t.STAR], '')\n}\n\nconst replaceGTE0 = (comp, options) => {\n debug('replaceGTE0', comp, options)\n return comp\n .trim()\n .replace(re[options.includePrerelease ? t.GTE0PRE : t.GTE0], '')\n}\n\n// This function is passed to string.replace(re[t.HYPHENRANGE])\n// M, m, patch, prerelease, build\n// 1.2 - 3.4.5 => >=1.2.0 <=3.4.5\n// 1.2.3 - 3.4 => >=1.2.0 <3.5.0-0 Any 3.4.x will do\n// 1.2 - 3.4 => >=1.2.0 <3.5.0-0\n// TODO build?\nconst hyphenReplace = incPr => ($0,\n from, fM, fm, fp, fpr, fb,\n to, tM, tm, tp, tpr) => {\n if (isX(fM)) {\n from = ''\n } else if (isX(fm)) {\n from = `>=${fM}.0.0${incPr ? '-0' : ''}`\n } else if (isX(fp)) {\n from = `>=${fM}.${fm}.0${incPr ? '-0' : ''}`\n } else if (fpr) {\n from = `>=${from}`\n } else {\n from = `>=${from}${incPr ? '-0' : ''}`\n }\n\n if (isX(tM)) {\n to = ''\n } else if (isX(tm)) {\n to = `<${+tM + 1}.0.0-0`\n } else if (isX(tp)) {\n to = `<${tM}.${+tm + 1}.0-0`\n } else if (tpr) {\n to = `<=${tM}.${tm}.${tp}-${tpr}`\n } else if (incPr) {\n to = `<${tM}.${tm}.${+tp + 1}-0`\n } else {\n to = `<=${to}`\n }\n\n return `${from} ${to}`.trim()\n}\n\nconst testSet = (set, version, options) => {\n for (let i = 0; i < set.length; i++) {\n if (!set[i].test(version)) {\n return false\n }\n }\n\n if (version.prerelease.length && !options.includePrerelease) {\n // Find the set of versions that are allowed to have prereleases\n // For example, ^1.2.3-pr.1 desugars to >=1.2.3-pr.1 <2.0.0\n // That should allow `1.2.3-pr.2` to pass.\n // However, `1.2.4-alpha.notready` should NOT be allowed,\n // even though it's within the range set by the comparators.\n for (let i = 0; i < set.length; i++) {\n debug(set[i].semver)\n if (set[i].semver === Comparator.ANY) {\n continue\n }\n\n if (set[i].semver.prerelease.length > 0) {\n const allowed = set[i].semver\n if (allowed.major === version.major &&\n allowed.minor === version.minor &&\n allowed.patch === version.patch) {\n return true\n }\n }\n }\n\n // Version has a -pre, but it's not one of the ones we like.\n return false\n }\n\n return true\n}\n","'use strict'\n\nconst ANY = Symbol('SemVer ANY')\n// hoisted class for cyclic dependency\nclass Comparator {\n static get ANY () {\n return ANY\n }\n\n constructor (comp, options) {\n options = parseOptions(options)\n\n if (comp instanceof Comparator) {\n if (comp.loose === !!options.loose) {\n return comp\n } else {\n comp = comp.value\n }\n }\n\n comp = comp.trim().split(/\\s+/).join(' ')\n debug('comparator', comp, options)\n this.options = options\n this.loose = !!options.loose\n this.parse(comp)\n\n if (this.semver === ANY) {\n this.value = ''\n } else {\n this.value = this.operator + this.semver.version\n }\n\n debug('comp', this)\n }\n\n parse (comp) {\n const r = this.options.loose ? re[t.COMPARATORLOOSE] : re[t.COMPARATOR]\n const m = comp.match(r)\n\n if (!m) {\n throw new TypeError(`Invalid comparator: ${comp}`)\n }\n\n this.operator = m[1] !== undefined ? m[1] : ''\n if (this.operator === '=') {\n this.operator = ''\n }\n\n // if it literally is just '>' or '' then allow anything.\n if (!m[2]) {\n this.semver = ANY\n } else {\n this.semver = new SemVer(m[2], this.options.loose)\n }\n }\n\n toString () {\n return this.value\n }\n\n test (version) {\n debug('Comparator.test', version, this.options.loose)\n\n if (this.semver === ANY || version === ANY) {\n return true\n }\n\n if (typeof version === 'string') {\n try {\n version = new SemVer(version, this.options)\n } catch (er) {\n return false\n }\n }\n\n return cmp(version, this.operator, this.semver, this.options)\n }\n\n intersects (comp, options) {\n if (!(comp instanceof Comparator)) {\n throw new TypeError('a Comparator is required')\n }\n\n if (this.operator === '') {\n if (this.value === '') {\n return true\n }\n return new Range(comp.value, options).test(this.value)\n } else if (comp.operator === '') {\n if (comp.value === '') {\n return true\n }\n return new Range(this.value, options).test(comp.semver)\n }\n\n options = parseOptions(options)\n\n // Special cases where nothing can possibly be lower\n if (options.includePrerelease &&\n (this.value === '<0.0.0-0' || comp.value === '<0.0.0-0')) {\n return false\n }\n if (!options.includePrerelease &&\n (this.value.startsWith('<0.0.0') || comp.value.startsWith('<0.0.0'))) {\n return false\n }\n\n // Same direction increasing (> or >=)\n if (this.operator.startsWith('>') && comp.operator.startsWith('>')) {\n return true\n }\n // Same direction decreasing (< or <=)\n if (this.operator.startsWith('<') && comp.operator.startsWith('<')) {\n return true\n }\n // same SemVer and both sides are inclusive (<= or >=)\n if (\n (this.semver.version === comp.semver.version) &&\n this.operator.includes('=') && comp.operator.includes('=')) {\n return true\n }\n // opposite directions less than\n if (cmp(this.semver, '<', comp.semver, options) &&\n this.operator.startsWith('>') && comp.operator.startsWith('<')) {\n return true\n }\n // opposite directions greater than\n if (cmp(this.semver, '>', comp.semver, options) &&\n this.operator.startsWith('<') && comp.operator.startsWith('>')) {\n return true\n }\n return false\n }\n}\n\nmodule.exports = Comparator\n\nconst parseOptions = require('../internal/parse-options')\nconst { safeRe: re, t } = require('../internal/re')\nconst cmp = require('../functions/cmp')\nconst debug = require('../internal/debug')\nconst SemVer = require('./semver')\nconst Range = require('./range')\n","'use strict'\n\nconst Range = require('../classes/range')\nconst satisfies = (version, range, options) => {\n try {\n range = new Range(range, options)\n } catch (er) {\n return false\n }\n return range.test(version)\n}\nmodule.exports = satisfies\n","'use strict'\n\nconst Range = require('../classes/range')\n\n// Mostly just for testing and legacy API reasons\nconst toComparators = (range, options) =>\n new Range(range, options).set\n .map(comp => comp.map(c => c.value).join(' ').trim().split(' '))\n\nmodule.exports = toComparators\n","'use strict'\n\nconst SemVer = require('../classes/semver')\nconst Range = require('../classes/range')\n\nconst maxSatisfying = (versions, range, options) => {\n let max = null\n let maxSV = null\n let rangeObj = null\n try {\n rangeObj = new Range(range, options)\n } catch (er) {\n return null\n }\n versions.forEach((v) => {\n if (rangeObj.test(v)) {\n // satisfies(v, range, options)\n if (!max || maxSV.compare(v) === -1) {\n // compare(max, v, true)\n max = v\n maxSV = new SemVer(max, options)\n }\n }\n })\n return max\n}\nmodule.exports = maxSatisfying\n","'use strict'\n\nconst SemVer = require('../classes/semver')\nconst Range = require('../classes/range')\nconst minSatisfying = (versions, range, options) => {\n let min = null\n let minSV = null\n let rangeObj = null\n try {\n rangeObj = new Range(range, options)\n } catch (er) {\n return null\n }\n versions.forEach((v) => {\n if (rangeObj.test(v)) {\n // satisfies(v, range, options)\n if (!min || minSV.compare(v) === 1) {\n // compare(min, v, true)\n min = v\n minSV = new SemVer(min, options)\n }\n }\n })\n return min\n}\nmodule.exports = minSatisfying\n","'use strict'\n\nconst SemVer = require('../classes/semver')\nconst Range = require('../classes/range')\nconst gt = require('../functions/gt')\n\nconst minVersion = (range, loose) => {\n range = new Range(range, loose)\n\n let minver = new SemVer('0.0.0')\n if (range.test(minver)) {\n return minver\n }\n\n minver = new SemVer('0.0.0-0')\n if (range.test(minver)) {\n return minver\n }\n\n minver = null\n for (let i = 0; i < range.set.length; ++i) {\n const comparators = range.set[i]\n\n let setMin = null\n comparators.forEach((comparator) => {\n // Clone to avoid manipulating the comparator's semver object.\n const compver = new SemVer(comparator.semver.version)\n switch (comparator.operator) {\n case '>':\n if (compver.prerelease.length === 0) {\n compver.patch++\n } else {\n compver.prerelease.push(0)\n }\n compver.raw = compver.format()\n /* fallthrough */\n case '':\n case '>=':\n if (!setMin || gt(compver, setMin)) {\n setMin = compver\n }\n break\n case '<':\n case '<=':\n /* Ignore maximum versions */\n break\n /* istanbul ignore next */\n default:\n throw new Error(`Unexpected operation: ${comparator.operator}`)\n }\n })\n if (setMin && (!minver || gt(minver, setMin))) {\n minver = setMin\n }\n }\n\n if (minver && range.test(minver)) {\n return minver\n }\n\n return null\n}\nmodule.exports = minVersion\n","'use strict'\n\nconst Range = require('../classes/range')\nconst validRange = (range, options) => {\n try {\n // Return '*' instead of '' so that truthiness works.\n // This will throw if it's invalid anyway\n return new Range(range, options).range || '*'\n } catch (er) {\n return null\n }\n}\nmodule.exports = validRange\n","'use strict'\n\nconst SemVer = require('../classes/semver')\nconst Comparator = require('../classes/comparator')\nconst { ANY } = Comparator\nconst Range = require('../classes/range')\nconst satisfies = require('../functions/satisfies')\nconst gt = require('../functions/gt')\nconst lt = require('../functions/lt')\nconst lte = require('../functions/lte')\nconst gte = require('../functions/gte')\n\nconst outside = (version, range, hilo, options) => {\n version = new SemVer(version, options)\n range = new Range(range, options)\n\n let gtfn, ltefn, ltfn, comp, ecomp\n switch (hilo) {\n case '>':\n gtfn = gt\n ltefn = lte\n ltfn = lt\n comp = '>'\n ecomp = '>='\n break\n case '<':\n gtfn = lt\n ltefn = gte\n ltfn = gt\n comp = '<'\n ecomp = '<='\n break\n default:\n throw new TypeError('Must provide a hilo val of \"<\" or \">\"')\n }\n\n // If it satisfies the range it is not outside\n if (satisfies(version, range, options)) {\n return false\n }\n\n // From now on, variable terms are as if we're in \"gtr\" mode.\n // but note that everything is flipped for the \"ltr\" function.\n\n for (let i = 0; i < range.set.length; ++i) {\n const comparators = range.set[i]\n\n let high = null\n let low = null\n\n comparators.forEach((comparator) => {\n if (comparator.semver === ANY) {\n comparator = new Comparator('>=0.0.0')\n }\n high = high || comparator\n low = low || comparator\n if (gtfn(comparator.semver, high.semver, options)) {\n high = comparator\n } else if (ltfn(comparator.semver, low.semver, options)) {\n low = comparator\n }\n })\n\n // If the edge version comparator has a operator then our version\n // isn't outside it\n if (high.operator === comp || high.operator === ecomp) {\n return false\n }\n\n // If the lowest version comparator has an operator and our version\n // is less than it then it isn't higher than the range\n if ((!low.operator || low.operator === comp) &&\n ltefn(version, low.semver)) {\n return false\n } else if (low.operator === ecomp && ltfn(version, low.semver)) {\n return false\n }\n }\n return true\n}\n\nmodule.exports = outside\n","'use strict'\n\n// Determine if version is greater than all the versions possible in the range.\nconst outside = require('./outside')\nconst gtr = (version, range, options) => outside(version, range, '>', options)\nmodule.exports = gtr\n","'use strict'\n\nconst outside = require('./outside')\n// Determine if version is less than all the versions possible in the range\nconst ltr = (version, range, options) => outside(version, range, '<', options)\nmodule.exports = ltr\n","'use strict'\n\nconst Range = require('../classes/range')\nconst intersects = (r1, r2, options) => {\n r1 = new Range(r1, options)\n r2 = new Range(r2, options)\n return r1.intersects(r2, options)\n}\nmodule.exports = intersects\n","'use strict'\n\n// given a set of versions and a range, create a \"simplified\" range\n// that includes the same versions that the original range does\n// If the original range is shorter than the simplified one, return that.\nconst satisfies = require('../functions/satisfies.js')\nconst compare = require('../functions/compare.js')\nmodule.exports = (versions, range, options) => {\n const set = []\n let first = null\n let prev = null\n const v = versions.sort((a, b) => compare(a, b, options))\n for (const version of v) {\n const included = satisfies(version, range, options)\n if (included) {\n prev = version\n if (!first) {\n first = version\n }\n } else {\n if (prev) {\n set.push([first, prev])\n }\n prev = null\n first = null\n }\n }\n if (first) {\n set.push([first, null])\n }\n\n const ranges = []\n for (const [min, max] of set) {\n if (min === max) {\n ranges.push(min)\n } else if (!max && min === v[0]) {\n ranges.push('*')\n } else if (!max) {\n ranges.push(`>=${min}`)\n } else if (min === v[0]) {\n ranges.push(`<=${max}`)\n } else {\n ranges.push(`${min} - ${max}`)\n }\n }\n const simplified = ranges.join(' || ')\n const original = typeof range.raw === 'string' ? range.raw : String(range)\n return simplified.length < original.length ? simplified : range\n}\n","'use strict'\n\nconst Range = require('../classes/range.js')\nconst Comparator = require('../classes/comparator.js')\nconst { ANY } = Comparator\nconst satisfies = require('../functions/satisfies.js')\nconst compare = require('../functions/compare.js')\n\n// Complex range `r1 || r2 || ...` is a subset of `R1 || R2 || ...` iff:\n// - Every simple range `r1, r2, ...` is a null set, OR\n// - Every simple range `r1, r2, ...` which is not a null set is a subset of\n// some `R1, R2, ...`\n//\n// Simple range `c1 c2 ...` is a subset of simple range `C1 C2 ...` iff:\n// - If c is only the ANY comparator\n// - If C is only the ANY comparator, return true\n// - Else if in prerelease mode, return false\n// - else replace c with `[>=0.0.0]`\n// - If C is only the ANY comparator\n// - if in prerelease mode, return true\n// - else replace C with `[>=0.0.0]`\n// - Let EQ be the set of = comparators in c\n// - If EQ is more than one, return true (null set)\n// - Let GT be the highest > or >= comparator in c\n// - Let LT be the lowest < or <= comparator in c\n// - If GT and LT, and GT.semver > LT.semver, return true (null set)\n// - If any C is a = range, and GT or LT are set, return false\n// - If EQ\n// - If GT, and EQ does not satisfy GT, return true (null set)\n// - If LT, and EQ does not satisfy LT, return true (null set)\n// - If EQ satisfies every C, return true\n// - Else return false\n// - If GT\n// - If GT.semver is lower than any > or >= comp in C, return false\n// - If GT is >=, and GT.semver does not satisfy every C, return false\n// - If GT.semver has a prerelease, and not in prerelease mode\n// - If no C has a prerelease and the GT.semver tuple, return false\n// - If LT\n// - If LT.semver is greater than any < or <= comp in C, return false\n// - If LT is <=, and LT.semver does not satisfy every C, return false\n// - If GT.semver has a prerelease, and not in prerelease mode\n// - If no C has a prerelease and the LT.semver tuple, return false\n// - Else return true\n\nconst subset = (sub, dom, options = {}) => {\n if (sub === dom) {\n return true\n }\n\n sub = new Range(sub, options)\n dom = new Range(dom, options)\n let sawNonNull = false\n\n OUTER: for (const simpleSub of sub.set) {\n for (const simpleDom of dom.set) {\n const isSub = simpleSubset(simpleSub, simpleDom, options)\n sawNonNull = sawNonNull || isSub !== null\n if (isSub) {\n continue OUTER\n }\n }\n // the null set is a subset of everything, but null simple ranges in\n // a complex range should be ignored. so if we saw a non-null range,\n // then we know this isn't a subset, but if EVERY simple range was null,\n // then it is a subset.\n if (sawNonNull) {\n return false\n }\n }\n return true\n}\n\nconst minimumVersionWithPreRelease = [new Comparator('>=0.0.0-0')]\nconst minimumVersion = [new Comparator('>=0.0.0')]\n\nconst simpleSubset = (sub, dom, options) => {\n if (sub === dom) {\n return true\n }\n\n if (sub.length === 1 && sub[0].semver === ANY) {\n if (dom.length === 1 && dom[0].semver === ANY) {\n return true\n } else if (options.includePrerelease) {\n sub = minimumVersionWithPreRelease\n } else {\n sub = minimumVersion\n }\n }\n\n if (dom.length === 1 && dom[0].semver === ANY) {\n if (options.includePrerelease) {\n return true\n } else {\n dom = minimumVersion\n }\n }\n\n const eqSet = new Set()\n let gt, lt\n for (const c of sub) {\n if (c.operator === '>' || c.operator === '>=') {\n gt = higherGT(gt, c, options)\n } else if (c.operator === '<' || c.operator === '<=') {\n lt = lowerLT(lt, c, options)\n } else {\n eqSet.add(c.semver)\n }\n }\n\n if (eqSet.size > 1) {\n return null\n }\n\n let gtltComp\n if (gt && lt) {\n gtltComp = compare(gt.semver, lt.semver, options)\n if (gtltComp > 0) {\n return null\n } else if (gtltComp === 0 && (gt.operator !== '>=' || lt.operator !== '<=')) {\n return null\n }\n }\n\n // will iterate one or zero times\n for (const eq of eqSet) {\n if (gt && !satisfies(eq, String(gt), options)) {\n return null\n }\n\n if (lt && !satisfies(eq, String(lt), options)) {\n return null\n }\n\n for (const c of dom) {\n if (!satisfies(eq, String(c), options)) {\n return false\n }\n }\n\n return true\n }\n\n let higher, lower\n let hasDomLT, hasDomGT\n // if the subset has a prerelease, we need a comparator in the superset\n // with the same tuple and a prerelease, or it's not a subset\n let needDomLTPre = lt &&\n !options.includePrerelease &&\n lt.semver.prerelease.length ? lt.semver : false\n let needDomGTPre = gt &&\n !options.includePrerelease &&\n gt.semver.prerelease.length ? gt.semver : false\n // exception: <1.2.3-0 is the same as <1.2.3\n if (needDomLTPre && needDomLTPre.prerelease.length === 1 &&\n lt.operator === '<' && needDomLTPre.prerelease[0] === 0) {\n needDomLTPre = false\n }\n\n for (const c of dom) {\n hasDomGT = hasDomGT || c.operator === '>' || c.operator === '>='\n hasDomLT = hasDomLT || c.operator === '<' || c.operator === '<='\n if (gt) {\n if (needDomGTPre) {\n if (c.semver.prerelease && c.semver.prerelease.length &&\n c.semver.major === needDomGTPre.major &&\n c.semver.minor === needDomGTPre.minor &&\n c.semver.patch === needDomGTPre.patch) {\n needDomGTPre = false\n }\n }\n if (c.operator === '>' || c.operator === '>=') {\n higher = higherGT(gt, c, options)\n if (higher === c && higher !== gt) {\n return false\n }\n } else if (gt.operator === '>=' && !satisfies(gt.semver, String(c), options)) {\n return false\n }\n }\n if (lt) {\n if (needDomLTPre) {\n if (c.semver.prerelease && c.semver.prerelease.length &&\n c.semver.major === needDomLTPre.major &&\n c.semver.minor === needDomLTPre.minor &&\n c.semver.patch === needDomLTPre.patch) {\n needDomLTPre = false\n }\n }\n if (c.operator === '<' || c.operator === '<=') {\n lower = lowerLT(lt, c, options)\n if (lower === c && lower !== lt) {\n return false\n }\n } else if (lt.operator === '<=' && !satisfies(lt.semver, String(c), options)) {\n return false\n }\n }\n if (!c.operator && (lt || gt) && gtltComp !== 0) {\n return false\n }\n }\n\n // if there was a < or >, and nothing in the dom, then must be false\n // UNLESS it was limited by another range in the other direction.\n // Eg, >1.0.0 <1.0.1 is still a subset of <2.0.0\n if (gt && hasDomLT && !lt && gtltComp !== 0) {\n return false\n }\n\n if (lt && hasDomGT && !gt && gtltComp !== 0) {\n return false\n }\n\n // we needed a prerelease range in a specific tuple, but didn't get one\n // then this isn't a subset. eg >=1.2.3-pre is not a subset of >=1.0.0,\n // because it includes prereleases in the 1.2.3 tuple\n if (needDomGTPre || needDomLTPre) {\n return false\n }\n\n return true\n}\n\n// >=1.2.3 is lower than >1.2.3\nconst higherGT = (a, b, options) => {\n if (!a) {\n return b\n }\n const comp = compare(a.semver, b.semver, options)\n return comp > 0 ? a\n : comp < 0 ? b\n : b.operator === '>' && a.operator === '>=' ? b\n : a\n}\n\n// <=1.2.3 is higher than <1.2.3\nconst lowerLT = (a, b, options) => {\n if (!a) {\n return b\n }\n const comp = compare(a.semver, b.semver, options)\n return comp < 0 ? a\n : comp > 0 ? b\n : b.operator === '<' && a.operator === '<=' ? b\n : a\n}\n\nmodule.exports = subset\n","'use strict'\n\n// just pre-load all the stuff that index.js lazily exports\nconst internalRe = require('./internal/re')\nconst constants = require('./internal/constants')\nconst SemVer = require('./classes/semver')\nconst identifiers = require('./internal/identifiers')\nconst parse = require('./functions/parse')\nconst valid = require('./functions/valid')\nconst clean = require('./functions/clean')\nconst inc = require('./functions/inc')\nconst diff = require('./functions/diff')\nconst major = require('./functions/major')\nconst minor = require('./functions/minor')\nconst patch = require('./functions/patch')\nconst prerelease = require('./functions/prerelease')\nconst compare = require('./functions/compare')\nconst rcompare = require('./functions/rcompare')\nconst compareLoose = require('./functions/compare-loose')\nconst compareBuild = require('./functions/compare-build')\nconst sort = require('./functions/sort')\nconst rsort = require('./functions/rsort')\nconst gt = require('./functions/gt')\nconst lt = require('./functions/lt')\nconst eq = require('./functions/eq')\nconst neq = require('./functions/neq')\nconst gte = require('./functions/gte')\nconst lte = require('./functions/lte')\nconst cmp = require('./functions/cmp')\nconst coerce = require('./functions/coerce')\nconst Comparator = require('./classes/comparator')\nconst Range = require('./classes/range')\nconst satisfies = require('./functions/satisfies')\nconst toComparators = require('./ranges/to-comparators')\nconst maxSatisfying = require('./ranges/max-satisfying')\nconst minSatisfying = require('./ranges/min-satisfying')\nconst minVersion = require('./ranges/min-version')\nconst validRange = require('./ranges/valid')\nconst outside = require('./ranges/outside')\nconst gtr = require('./ranges/gtr')\nconst ltr = require('./ranges/ltr')\nconst intersects = require('./ranges/intersects')\nconst simplifyRange = require('./ranges/simplify')\nconst subset = require('./ranges/subset')\nmodule.exports = {\n parse,\n valid,\n clean,\n inc,\n diff,\n major,\n minor,\n patch,\n prerelease,\n compare,\n rcompare,\n compareLoose,\n compareBuild,\n sort,\n rsort,\n gt,\n lt,\n eq,\n neq,\n gte,\n lte,\n cmp,\n coerce,\n Comparator,\n Range,\n satisfies,\n toComparators,\n maxSatisfying,\n minSatisfying,\n minVersion,\n validRange,\n outside,\n gtr,\n ltr,\n intersects,\n simplifyRange,\n subset,\n SemVer,\n re: internalRe.re,\n src: internalRe.src,\n tokens: internalRe.t,\n SEMVER_SPEC_VERSION: constants.SEMVER_SPEC_VERSION,\n RELEASE_TYPES: constants.RELEASE_TYPES,\n compareIdentifiers: identifiers.compareIdentifiers,\n rcompareIdentifiers: identifiers.rcompareIdentifiers,\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isVersionGreaterOrEqual = isVersionGreaterOrEqual;\nexports.parsePromptIdentifier = parsePromptIdentifier;\nconst semver_1 = require(\"semver\");\nfunction isVersionGreaterOrEqual(current_version, target_version) {\n const current = (0, semver_1.parse)(current_version);\n const target = (0, semver_1.parse)(target_version);\n if (!current || !target) {\n throw new Error(\"Invalid version format.\");\n }\n return current.compare(target) >= 0;\n}\nfunction parsePromptIdentifier(identifier) {\n if (!identifier ||\n identifier.split(\"/\").length > 2 ||\n identifier.startsWith(\"/\") ||\n identifier.endsWith(\"/\") ||\n identifier.split(\":\").length > 2) {\n throw new Error(`Invalid identifier format: ${identifier}`);\n }\n const [ownerNamePart, commitPart] = identifier.split(\":\");\n const commit = commitPart || \"latest\";\n if (ownerNamePart.includes(\"/\")) {\n const [owner, name] = ownerNamePart.split(\"/\", 2);\n if (!owner || !name) {\n throw new Error(`Invalid identifier format: ${identifier}`);\n }\n return [owner, name, commit];\n }\n else {\n if (!ownerNamePart) {\n throw new Error(`Invalid identifier format: ${identifier}`);\n }\n return [\"-\", ownerNamePart, commit];\n }\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ConflictingEndpointsError = exports.LangSmithConflictError = void 0;\nexports.printErrorStackTrace = printErrorStackTrace;\nexports.raiseForStatus = raiseForStatus;\nexports.isConflictingEndpointsError = isConflictingEndpointsError;\nfunction getErrorStackTrace(e) {\n if (typeof e !== \"object\" || e == null)\n return undefined;\n if (!(\"stack\" in e) || typeof e.stack !== \"string\")\n return undefined;\n let stack = e.stack;\n const prevLine = `${e}`;\n if (stack.startsWith(prevLine)) {\n stack = stack.slice(prevLine.length);\n }\n if (stack.startsWith(\"\\n\")) {\n stack = stack.slice(1);\n }\n return stack;\n}\nfunction printErrorStackTrace(e) {\n const stack = getErrorStackTrace(e);\n if (stack == null)\n return;\n console.error(stack);\n}\n/**\n * LangSmithConflictError\n *\n * Represents an error that occurs when there's a conflict during an operation,\n * typically corresponding to HTTP 409 status code responses.\n *\n * This error is thrown when an attempt to create or modify a resource conflicts\n * with the current state of the resource on the server. Common scenarios include:\n * - Attempting to create a resource that already exists\n * - Trying to update a resource that has been modified by another process\n * - Violating a uniqueness constraint in the data\n *\n * @extends Error\n *\n * @example\n * try {\n * await createProject(\"existingProject\");\n * } catch (error) {\n * if (error instanceof ConflictError) {\n * console.log(\"A conflict occurred:\", error.message);\n * // Handle the conflict, e.g., by suggesting a different project name\n * } else {\n * // Handle other types of errors\n * }\n * }\n *\n * @property {string} name - Always set to 'ConflictError' for easy identification\n * @property {string} message - Detailed error message including server response\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/409\n */\nclass LangSmithConflictError extends Error {\n constructor(message) {\n super(message);\n Object.defineProperty(this, \"status\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.name = \"LangSmithConflictError\";\n this.status = 409;\n }\n}\nexports.LangSmithConflictError = LangSmithConflictError;\n/**\n * Throws an appropriate error based on the response status and body.\n *\n * @param response - The fetch Response object\n * @param context - Additional context to include in the error message (e.g., operation being performed)\n * @throws {LangSmithConflictError} When the response status is 409\n * @throws {Error} For all other non-ok responses\n */\nasync function raiseForStatus(response, context, consumeOnSuccess) {\n let errorBody;\n if (response.ok) {\n // consume the response body to release the connection\n // https://undici.nodejs.org/#/?id=garbage-collection\n if (consumeOnSuccess) {\n errorBody = await response.text();\n }\n return;\n }\n if (response.status === 403) {\n try {\n const errorData = await response.json();\n const errorCode = errorData?.error;\n if (errorCode === \"org_scoped_key_requires_workspace\") {\n errorBody =\n \"This API key is org-scoped and requires workspace specification. \" +\n \"Please provide 'workspaceId' parameter, \" +\n \"or set LANGSMITH_WORKSPACE_ID environment variable.\";\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n }\n catch (e) {\n const errorWithStatus = new Error(`${response.status} ${response.statusText}`);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n errorWithStatus.status = response?.status;\n throw errorWithStatus;\n }\n }\n if (errorBody === undefined) {\n try {\n errorBody = await response.text();\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n }\n catch (e) {\n errorBody = \"\";\n }\n }\n const fullMessage = `Failed to ${context}. Received status [${response.status}]: ${response.statusText}. Message: ${errorBody}`;\n if (response.status === 409) {\n throw new LangSmithConflictError(fullMessage);\n }\n const err = new Error(fullMessage);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n err.status = response.status;\n throw err;\n}\nconst ERR_CONFLICTING_ENDPOINTS = \"ERR_CONFLICTING_ENDPOINTS\";\nclass ConflictingEndpointsError extends Error {\n constructor() {\n super(\"You cannot provide both LANGSMITH_ENDPOINT / LANGCHAIN_ENDPOINT \" +\n \"and LANGSMITH_RUNS_ENDPOINTS.\");\n Object.defineProperty(this, \"code\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: ERR_CONFLICTING_ENDPOINTS\n });\n this.name = \"ConflictingEndpointsError\"; // helpful in logs\n }\n}\nexports.ConflictingEndpointsError = ConflictingEndpointsError;\nfunction isConflictingEndpointsError(err) {\n return (typeof err === \"object\" &&\n err !== null &&\n err.code === ERR_CONFLICTING_ENDPOINTS);\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.serialize = serialize;\n/* eslint-disable */\n// @ts-nocheck\nconst env_js_1 = require(\"../../utils/env.cjs\");\nvar LIMIT_REPLACE_NODE = \"[...]\";\nvar CIRCULAR_REPLACE_NODE = { result: \"[Circular]\" };\nvar arr = [];\nvar replacerStack = [];\nconst encoder = new TextEncoder();\nfunction defaultOptions() {\n return {\n depthLimit: Number.MAX_SAFE_INTEGER,\n edgesLimit: Number.MAX_SAFE_INTEGER,\n };\n}\nfunction encodeString(str) {\n return encoder.encode(str);\n}\n// Shared function to handle well-known types\nfunction serializeWellKnownTypes(val) {\n if (val && typeof val === \"object\" && val !== null) {\n if (val instanceof Map) {\n return Object.fromEntries(val);\n }\n else if (val instanceof Set) {\n return Array.from(val);\n }\n else if (val instanceof Date) {\n return val.toISOString();\n }\n else if (val instanceof RegExp) {\n return val.toString();\n }\n else if (val instanceof Error) {\n return {\n name: val.name,\n message: val.message,\n };\n }\n }\n else if (typeof val === \"bigint\") {\n return val.toString();\n }\n return val;\n}\n// Default replacer function to handle well-known types\nfunction createDefaultReplacer(userReplacer) {\n return function (key, val) {\n // Apply user replacer first if provided\n if (userReplacer) {\n const userResult = userReplacer.call(this, key, val);\n // If user replacer returned undefined, fall back to our serialization\n if (userResult !== undefined) {\n return userResult;\n }\n }\n // Fall back to our well-known type handling\n return serializeWellKnownTypes(val);\n };\n}\n// Regular stringify\nfunction serialize(obj, errorContext, replacer, spacer, options) {\n try {\n const str = JSON.stringify(obj, createDefaultReplacer(replacer), spacer);\n return encodeString(str);\n }\n catch (e) {\n // Fall back to more complex stringify if circular reference\n if (!e.message?.includes(\"Converting circular structure to JSON\")) {\n console.warn(`[WARNING]: LangSmith received unserializable value.${errorContext ? `\\nContext: ${errorContext}` : \"\"}`);\n return encodeString(\"[Unserializable]\");\n }\n (0, env_js_1.getLangSmithEnvironmentVariable)(\"SUPPRESS_CIRCULAR_JSON_WARNINGS\") !==\n \"true\" &&\n console.warn(`[WARNING]: LangSmith received circular JSON. This will decrease tracer performance. ${errorContext ? `\\nContext: ${errorContext}` : \"\"}`);\n if (typeof options === \"undefined\") {\n options = defaultOptions();\n }\n decirc(obj, \"\", 0, [], undefined, 0, options);\n let res;\n try {\n if (replacerStack.length === 0) {\n res = JSON.stringify(obj, replacer, spacer);\n }\n else {\n res = JSON.stringify(obj, replaceGetterValues(replacer), spacer);\n }\n }\n catch (_) {\n return encodeString(\"[unable to serialize, circular reference is too complex to analyze]\");\n }\n finally {\n while (arr.length !== 0) {\n const part = arr.pop();\n if (part.length === 4) {\n Object.defineProperty(part[0], part[1], part[3]);\n }\n else {\n part[0][part[1]] = part[2];\n }\n }\n }\n return encodeString(res);\n }\n}\nfunction setReplace(replace, val, k, parent) {\n var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k);\n if (propertyDescriptor.get !== undefined) {\n if (propertyDescriptor.configurable) {\n Object.defineProperty(parent, k, { value: replace });\n arr.push([parent, k, val, propertyDescriptor]);\n }\n else {\n replacerStack.push([val, k, replace]);\n }\n }\n else {\n parent[k] = replace;\n arr.push([parent, k, val]);\n }\n}\nfunction decirc(val, k, edgeIndex, stack, parent, depth, options) {\n depth += 1;\n var i;\n if (typeof val === \"object\" && val !== null) {\n for (i = 0; i < stack.length; i++) {\n if (stack[i] === val) {\n setReplace(CIRCULAR_REPLACE_NODE, val, k, parent);\n return;\n }\n }\n if (typeof options.depthLimit !== \"undefined\" &&\n depth > options.depthLimit) {\n setReplace(LIMIT_REPLACE_NODE, val, k, parent);\n return;\n }\n if (typeof options.edgesLimit !== \"undefined\" &&\n edgeIndex + 1 > options.edgesLimit) {\n setReplace(LIMIT_REPLACE_NODE, val, k, parent);\n return;\n }\n stack.push(val);\n // Optimize for Arrays. Big arrays could kill the performance otherwise!\n if (Array.isArray(val)) {\n for (i = 0; i < val.length; i++) {\n decirc(val[i], i, i, stack, val, depth, options);\n }\n }\n else {\n // Handle well-known types before Object.keys iteration\n val = serializeWellKnownTypes(val);\n var keys = Object.keys(val);\n for (i = 0; i < keys.length; i++) {\n var key = keys[i];\n decirc(val[key], key, i, stack, val, depth, options);\n }\n }\n stack.pop();\n }\n}\n// Stable-stringify\nfunction compareFunction(a, b) {\n if (a < b) {\n return -1;\n }\n if (a > b) {\n return 1;\n }\n return 0;\n}\nfunction deterministicStringify(obj, replacer, spacer, options) {\n if (typeof options === \"undefined\") {\n options = defaultOptions();\n }\n var tmp = deterministicDecirc(obj, \"\", 0, [], undefined, 0, options) || obj;\n var res;\n try {\n if (replacerStack.length === 0) {\n res = JSON.stringify(tmp, replacer, spacer);\n }\n else {\n res = JSON.stringify(tmp, replaceGetterValues(replacer), spacer);\n }\n }\n catch (_) {\n return JSON.stringify(\"[unable to serialize, circular reference is too complex to analyze]\");\n }\n finally {\n // Ensure that we restore the object as it was.\n while (arr.length !== 0) {\n var part = arr.pop();\n if (part.length === 4) {\n Object.defineProperty(part[0], part[1], part[3]);\n }\n else {\n part[0][part[1]] = part[2];\n }\n }\n }\n return res;\n}\nfunction deterministicDecirc(val, k, edgeIndex, stack, parent, depth, options) {\n depth += 1;\n var i;\n if (typeof val === \"object\" && val !== null) {\n for (i = 0; i < stack.length; i++) {\n if (stack[i] === val) {\n setReplace(CIRCULAR_REPLACE_NODE, val, k, parent);\n return;\n }\n }\n try {\n if (typeof val.toJSON === \"function\") {\n return;\n }\n }\n catch (_) {\n return;\n }\n if (typeof options.depthLimit !== \"undefined\" &&\n depth > options.depthLimit) {\n setReplace(LIMIT_REPLACE_NODE, val, k, parent);\n return;\n }\n if (typeof options.edgesLimit !== \"undefined\" &&\n edgeIndex + 1 > options.edgesLimit) {\n setReplace(LIMIT_REPLACE_NODE, val, k, parent);\n return;\n }\n stack.push(val);\n // Optimize for Arrays. Big arrays could kill the performance otherwise!\n if (Array.isArray(val)) {\n for (i = 0; i < val.length; i++) {\n deterministicDecirc(val[i], i, i, stack, val, depth, options);\n }\n }\n else {\n // Handle well-known types before Object.keys iteration\n val = serializeWellKnownTypes(val);\n // Create a temporary object in the required way\n var tmp = {};\n var keys = Object.keys(val).sort(compareFunction);\n for (i = 0; i < keys.length; i++) {\n var key = keys[i];\n deterministicDecirc(val[key], key, i, stack, val, depth, options);\n tmp[key] = val[key];\n }\n if (typeof parent !== \"undefined\") {\n arr.push([parent, k, val]);\n parent[k] = tmp;\n }\n else {\n return tmp;\n }\n }\n stack.pop();\n }\n}\n// wraps replacer function to handle values we couldn't replace\n// and mark them as replaced value\nfunction replaceGetterValues(replacer) {\n replacer =\n typeof replacer !== \"undefined\"\n ? replacer\n : function (k, v) {\n return v;\n };\n return function (key, val) {\n if (replacerStack.length > 0) {\n for (var i = 0; i < replacerStack.length; i++) {\n var part = replacerStack[i];\n if (part[1] === key && part[0] === val) {\n val = part[2];\n replacerStack.splice(i, 1);\n break;\n }\n }\n }\n return replacer.call(this, key, val);\n };\n}\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || (function () {\n var ownKeys = function(o) {\n ownKeys = Object.getOwnPropertyNames || function (o) {\n var ar = [];\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\n return ar;\n };\n return ownKeys(o);\n };\n return function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\n __setModuleDefault(result, mod);\n return result;\n };\n})();\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Client = exports.AutoBatchQueue = exports.DEFAULT_MAX_SIZE_BYTES = exports.DEFAULT_UNCOMPRESSED_BATCH_SIZE_LIMIT_BYTES = void 0;\nexports.mergeRuntimeEnvIntoRun = mergeRuntimeEnvIntoRun;\nconst uuid = __importStar(require(\"uuid\"));\nconst translator_js_1 = require(\"./experimental/otel/translator.cjs\");\nconst otel_js_1 = require(\"./singletons/otel.cjs\");\nconst async_caller_js_1 = require(\"./utils/async_caller.cjs\");\nconst messages_js_1 = require(\"./utils/messages.cjs\");\nconst env_js_1 = require(\"./utils/env.cjs\");\nconst index_js_1 = require(\"./index.cjs\");\nconst _uuid_js_1 = require(\"./utils/_uuid.cjs\");\nconst warn_js_1 = require(\"./utils/warn.cjs\");\nconst prompts_js_1 = require(\"./utils/prompts.cjs\");\nconst error_js_1 = require(\"./utils/error.cjs\");\nconst fetch_js_1 = require(\"./singletons/fetch.cjs\");\nconst index_js_2 = require(\"./utils/fast-safe-stringify/index.cjs\");\nfunction mergeRuntimeEnvIntoRun(run, cachedEnvVars, omitTracedRuntimeInfo) {\n if (omitTracedRuntimeInfo) {\n return run;\n }\n const runtimeEnv = (0, env_js_1.getRuntimeEnvironment)();\n const envVars = cachedEnvVars ?? (0, env_js_1.getLangSmithEnvVarsMetadata)();\n const extra = run.extra ?? {};\n const metadata = extra.metadata;\n run.extra = {\n ...extra,\n runtime: {\n ...runtimeEnv,\n ...extra?.runtime,\n },\n metadata: {\n ...envVars,\n ...(envVars.revision_id || (\"revision_id\" in run && run.revision_id)\n ? {\n revision_id: (\"revision_id\" in run ? run.revision_id : undefined) ??\n envVars.revision_id,\n }\n : {}),\n ...metadata,\n },\n };\n return run;\n}\nconst getTracingSamplingRate = (configRate) => {\n const samplingRateStr = configRate?.toString() ??\n (0, env_js_1.getLangSmithEnvironmentVariable)(\"TRACING_SAMPLING_RATE\");\n if (samplingRateStr === undefined) {\n return undefined;\n }\n const samplingRate = parseFloat(samplingRateStr);\n if (samplingRate < 0 || samplingRate > 1) {\n throw new Error(`LANGSMITH_TRACING_SAMPLING_RATE must be between 0 and 1 if set. Got: ${samplingRate}`);\n }\n return samplingRate;\n};\n// utility functions\nconst isLocalhost = (url) => {\n const strippedUrl = url.replace(\"http://\", \"\").replace(\"https://\", \"\");\n const hostname = strippedUrl.split(\"/\")[0].split(\":\")[0];\n return (hostname === \"localhost\" || hostname === \"127.0.0.1\" || hostname === \"::1\");\n};\nasync function toArray(iterable) {\n const result = [];\n for await (const item of iterable) {\n result.push(item);\n }\n return result;\n}\nfunction trimQuotes(str) {\n if (str === undefined) {\n return undefined;\n }\n return str\n .trim()\n .replace(/^\"(.*)\"$/, \"$1\")\n .replace(/^'(.*)'$/, \"$1\");\n}\nconst handle429 = async (response) => {\n if (response?.status === 429) {\n const retryAfter = parseInt(response.headers.get(\"retry-after\") ?? \"10\", 10) * 1000;\n if (retryAfter > 0) {\n await new Promise((resolve) => setTimeout(resolve, retryAfter));\n // Return directly after calling this check\n return true;\n }\n }\n // Fall back to existing status checks\n return false;\n};\nfunction _formatFeedbackScore(score) {\n if (typeof score === \"number\") {\n // Truncate at 4 decimal places\n return Number(score.toFixed(4));\n }\n return score;\n}\nexports.DEFAULT_UNCOMPRESSED_BATCH_SIZE_LIMIT_BYTES = 24 * 1024 * 1024;\n/** Default maximum memory (1GB) for queue size limits. */\nexports.DEFAULT_MAX_SIZE_BYTES = 1024 * 1024 * 1024; // 1GB\nconst SERVER_INFO_REQUEST_TIMEOUT_MS = 10000;\n/** Maximum number of operations to batch in a single request. */\nconst DEFAULT_BATCH_SIZE_LIMIT = 100;\nconst DEFAULT_API_URL = \"https://api.smith.langchain.com\";\nclass AutoBatchQueue {\n constructor(maxSizeBytes) {\n Object.defineProperty(this, \"items\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: []\n });\n Object.defineProperty(this, \"sizeBytes\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: 0\n });\n Object.defineProperty(this, \"maxSizeBytes\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.maxSizeBytes = maxSizeBytes ?? exports.DEFAULT_MAX_SIZE_BYTES;\n }\n peek() {\n return this.items[0];\n }\n push(item) {\n let itemPromiseResolve;\n const itemPromise = new Promise((resolve) => {\n // Setting itemPromiseResolve is synchronous with promise creation:\n // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/Promise\n itemPromiseResolve = resolve;\n });\n const size = (0, index_js_2.serialize)(item.item, `Serializing run with id: ${item.item.id}`).length;\n // Check if adding this item would exceed the size limit\n // Allow the run if the queue is empty (to support large single traces)\n if (this.sizeBytes + size > this.maxSizeBytes && this.items.length > 0) {\n console.warn(`AutoBatchQueue size limit (${this.maxSizeBytes} bytes) exceeded. Dropping run with id: ${item.item.id}. ` +\n `Current queue size: ${this.sizeBytes} bytes, attempted addition: ${size} bytes.`);\n // Resolve immediately to avoid blocking caller\n itemPromiseResolve();\n return itemPromise;\n }\n this.items.push({\n action: item.action,\n payload: item.item,\n otelContext: item.otelContext,\n apiKey: item.apiKey,\n apiUrl: item.apiUrl,\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n itemPromiseResolve: itemPromiseResolve,\n itemPromise,\n size,\n });\n this.sizeBytes += size;\n return itemPromise;\n }\n pop({ upToSizeBytes, upToSize, }) {\n if (upToSizeBytes < 1) {\n throw new Error(\"Number of bytes to pop off may not be less than 1.\");\n }\n const popped = [];\n let poppedSizeBytes = 0;\n // Pop items until we reach or exceed the size limit\n while (poppedSizeBytes + (this.peek()?.size ?? 0) < upToSizeBytes &&\n this.items.length > 0 &&\n popped.length < upToSize) {\n const item = this.items.shift();\n if (item) {\n popped.push(item);\n poppedSizeBytes += item.size;\n this.sizeBytes -= item.size;\n }\n }\n // If there is an item on the queue we were unable to pop,\n // just return it as a single batch.\n if (popped.length === 0 && this.items.length > 0) {\n const item = this.items.shift();\n popped.push(item);\n poppedSizeBytes += item.size;\n this.sizeBytes -= item.size;\n }\n return [\n popped.map((it) => ({\n action: it.action,\n item: it.payload,\n otelContext: it.otelContext,\n apiKey: it.apiKey,\n apiUrl: it.apiUrl,\n size: it.size,\n })),\n () => popped.forEach((it) => it.itemPromiseResolve()),\n ];\n }\n}\nexports.AutoBatchQueue = AutoBatchQueue;\nclass Client {\n get _fetch() {\n return this.fetchImplementation || (0, fetch_js_1._getFetchImplementation)(this.debug);\n }\n constructor(config = {}) {\n Object.defineProperty(this, \"apiKey\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"apiUrl\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"webUrl\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"workspaceId\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"caller\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"batchIngestCaller\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"timeout_ms\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"_tenantId\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: null\n });\n Object.defineProperty(this, \"hideInputs\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"hideOutputs\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"omitTracedRuntimeInfo\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"tracingSampleRate\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"filteredPostUuids\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: new Set()\n });\n Object.defineProperty(this, \"autoBatchTracing\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: true\n });\n Object.defineProperty(this, \"autoBatchQueue\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"autoBatchTimeout\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"autoBatchAggregationDelayMs\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: 250\n });\n Object.defineProperty(this, \"batchSizeBytesLimit\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"batchSizeLimit\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"fetchOptions\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"settings\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"blockOnRootRunFinalization\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: (0, env_js_1.getEnvironmentVariable)(\"LANGSMITH_TRACING_BACKGROUND\") === \"false\"\n });\n Object.defineProperty(this, \"traceBatchConcurrency\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: 5\n });\n Object.defineProperty(this, \"_serverInfo\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Object.defineProperty(this, \"_getServerInfoPromise\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"manualFlushMode\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"langSmithToOTELTranslator\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"fetchImplementation\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"cachedLSEnvVarsForMetadata\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"multipartStreamingDisabled\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"debug\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: (0, env_js_1.getEnvironmentVariable)(\"LANGSMITH_DEBUG\") === \"true\"\n });\n const defaultConfig = Client.getDefaultClientConfig();\n this.tracingSampleRate = getTracingSamplingRate(config.tracingSamplingRate);\n this.apiUrl = trimQuotes(config.apiUrl ?? defaultConfig.apiUrl) ?? \"\";\n if (this.apiUrl.endsWith(\"/\")) {\n this.apiUrl = this.apiUrl.slice(0, -1);\n }\n this.apiKey = trimQuotes(config.apiKey ?? defaultConfig.apiKey);\n this.webUrl = trimQuotes(config.webUrl ?? defaultConfig.webUrl);\n if (this.webUrl?.endsWith(\"/\")) {\n this.webUrl = this.webUrl.slice(0, -1);\n }\n this.workspaceId = trimQuotes(config.workspaceId ?? (0, env_js_1.getLangSmithEnvironmentVariable)(\"WORKSPACE_ID\"));\n this.timeout_ms = config.timeout_ms ?? 90_000;\n this.caller = new async_caller_js_1.AsyncCaller({\n ...(config.callerOptions ?? {}),\n maxRetries: 4,\n debug: config.debug ?? this.debug,\n });\n this.traceBatchConcurrency =\n config.traceBatchConcurrency ?? this.traceBatchConcurrency;\n if (this.traceBatchConcurrency < 1) {\n throw new Error(\"Trace batch concurrency must be positive.\");\n }\n this.debug = config.debug ?? this.debug;\n this.fetchImplementation = config.fetchImplementation;\n // Use maxIngestMemoryBytes for both queues\n const maxMemory = config.maxIngestMemoryBytes ?? exports.DEFAULT_MAX_SIZE_BYTES;\n this.batchIngestCaller = new async_caller_js_1.AsyncCaller({\n maxRetries: 4,\n maxConcurrency: this.traceBatchConcurrency,\n maxQueueSizeBytes: maxMemory,\n ...(config.callerOptions ?? {}),\n onFailedResponseHook: handle429,\n debug: config.debug ?? this.debug,\n });\n this.hideInputs =\n config.hideInputs ?? config.anonymizer ?? defaultConfig.hideInputs;\n this.hideOutputs =\n config.hideOutputs ?? config.anonymizer ?? defaultConfig.hideOutputs;\n this.omitTracedRuntimeInfo = config.omitTracedRuntimeInfo ?? false;\n this.autoBatchTracing = config.autoBatchTracing ?? this.autoBatchTracing;\n this.autoBatchQueue = new AutoBatchQueue(maxMemory);\n this.blockOnRootRunFinalization =\n config.blockOnRootRunFinalization ?? this.blockOnRootRunFinalization;\n this.batchSizeBytesLimit = config.batchSizeBytesLimit;\n this.batchSizeLimit = config.batchSizeLimit;\n this.fetchOptions = config.fetchOptions || {};\n this.manualFlushMode = config.manualFlushMode ?? this.manualFlushMode;\n if ((0, env_js_1.getOtelEnabled)()) {\n this.langSmithToOTELTranslator = new translator_js_1.LangSmithToOTELTranslator();\n }\n // Cache metadata env vars once during construction to avoid repeatedly scanning process.env\n this.cachedLSEnvVarsForMetadata = (0, env_js_1.getLangSmithEnvVarsMetadata)();\n }\n static getDefaultClientConfig() {\n const apiKey = (0, env_js_1.getLangSmithEnvironmentVariable)(\"API_KEY\");\n const apiUrl = (0, env_js_1.getLangSmithEnvironmentVariable)(\"ENDPOINT\") ?? DEFAULT_API_URL;\n const hideInputs = (0, env_js_1.getLangSmithEnvironmentVariable)(\"HIDE_INPUTS\") === \"true\";\n const hideOutputs = (0, env_js_1.getLangSmithEnvironmentVariable)(\"HIDE_OUTPUTS\") === \"true\";\n return {\n apiUrl: apiUrl,\n apiKey: apiKey,\n webUrl: undefined,\n hideInputs: hideInputs,\n hideOutputs: hideOutputs,\n };\n }\n getHostUrl() {\n if (this.webUrl) {\n return this.webUrl;\n }\n else if (isLocalhost(this.apiUrl)) {\n this.webUrl = \"http://localhost:3000\";\n return this.webUrl;\n }\n else if (this.apiUrl.endsWith(\"/api/v1\")) {\n this.webUrl = this.apiUrl.replace(\"/api/v1\", \"\");\n return this.webUrl;\n }\n else if (this.apiUrl.includes(\"/api\") &&\n !this.apiUrl.split(\".\", 1)[0].endsWith(\"api\")) {\n this.webUrl = this.apiUrl.replace(\"/api\", \"\");\n return this.webUrl;\n }\n else if (this.apiUrl.split(\".\", 1)[0].includes(\"dev\")) {\n this.webUrl = \"https://dev.smith.langchain.com\";\n return this.webUrl;\n }\n else if (this.apiUrl.split(\".\", 1)[0].includes(\"eu\")) {\n this.webUrl = \"https://eu.smith.langchain.com\";\n return this.webUrl;\n }\n else if (this.apiUrl.split(\".\", 1)[0].includes(\"beta\")) {\n this.webUrl = \"https://beta.smith.langchain.com\";\n return this.webUrl;\n }\n else {\n this.webUrl = \"https://smith.langchain.com\";\n return this.webUrl;\n }\n }\n get headers() {\n const headers = {\n \"User-Agent\": `langsmith-js/${index_js_1.__version__}`,\n };\n if (this.apiKey) {\n headers[\"x-api-key\"] = `${this.apiKey}`;\n }\n if (this.workspaceId) {\n headers[\"x-tenant-id\"] = this.workspaceId;\n }\n return headers;\n }\n _getPlatformEndpointPath(path) {\n // Check if apiUrl already ends with /v1 or /v1/ to avoid double /v1/v1/ paths\n const needsV1Prefix = this.apiUrl.slice(-3) !== \"/v1\" && this.apiUrl.slice(-4) !== \"/v1/\";\n return needsV1Prefix ? `/v1/platform/${path}` : `/platform/${path}`;\n }\n async processInputs(inputs) {\n if (this.hideInputs === false) {\n return inputs;\n }\n if (this.hideInputs === true) {\n return {};\n }\n if (typeof this.hideInputs === \"function\") {\n return this.hideInputs(inputs);\n }\n return inputs;\n }\n async processOutputs(outputs) {\n if (this.hideOutputs === false) {\n return outputs;\n }\n if (this.hideOutputs === true) {\n return {};\n }\n if (typeof this.hideOutputs === \"function\") {\n return this.hideOutputs(outputs);\n }\n return outputs;\n }\n async prepareRunCreateOrUpdateInputs(run) {\n const runParams = { ...run };\n if (runParams.inputs !== undefined) {\n runParams.inputs = await this.processInputs(runParams.inputs);\n }\n if (runParams.outputs !== undefined) {\n runParams.outputs = await this.processOutputs(runParams.outputs);\n }\n return runParams;\n }\n async _getResponse(path, queryParams) {\n const paramsString = queryParams?.toString() ?? \"\";\n const url = `${this.apiUrl}${path}?${paramsString}`;\n const response = await this.caller.call(async () => {\n const res = await this._fetch(url, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, `fetch ${path}`);\n return res;\n });\n return response;\n }\n async _get(path, queryParams) {\n const response = await this._getResponse(path, queryParams);\n return response.json();\n }\n async *_getPaginated(path, queryParams = new URLSearchParams(), transform) {\n let offset = Number(queryParams.get(\"offset\")) || 0;\n const limit = Number(queryParams.get(\"limit\")) || 100;\n while (true) {\n queryParams.set(\"offset\", String(offset));\n queryParams.set(\"limit\", String(limit));\n const url = `${this.apiUrl}${path}?${queryParams}`;\n const response = await this.caller.call(async () => {\n const res = await this._fetch(url, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, `fetch ${path}`);\n return res;\n });\n const items = transform\n ? transform(await response.json())\n : await response.json();\n if (items.length === 0) {\n break;\n }\n yield items;\n if (items.length < limit) {\n break;\n }\n offset += items.length;\n }\n }\n async *_getCursorPaginatedList(path, body = null, requestMethod = \"POST\", dataKey = \"runs\") {\n const bodyParams = body ? { ...body } : {};\n while (true) {\n const body = JSON.stringify(bodyParams);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}${path}`, {\n method: requestMethod,\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, `fetch ${path}`);\n return res;\n });\n const responseBody = await response.json();\n if (!responseBody) {\n break;\n }\n if (!responseBody[dataKey]) {\n break;\n }\n yield responseBody[dataKey];\n const cursors = responseBody.cursors;\n if (!cursors) {\n break;\n }\n if (!cursors.next) {\n break;\n }\n bodyParams.cursor = cursors.next;\n }\n }\n // Allows mocking for tests\n _shouldSample() {\n if (this.tracingSampleRate === undefined) {\n return true;\n }\n return Math.random() < this.tracingSampleRate;\n }\n _filterForSampling(runs, patch = false) {\n if (this.tracingSampleRate === undefined) {\n return runs;\n }\n if (patch) {\n const sampled = [];\n for (const run of runs) {\n if (!this.filteredPostUuids.has(run.trace_id)) {\n sampled.push(run);\n }\n else if (run.id === run.trace_id) {\n this.filteredPostUuids.delete(run.trace_id);\n }\n }\n return sampled;\n }\n else {\n // For new runs, sample at trace level to maintain consistency\n const sampled = [];\n for (const run of runs) {\n const traceId = run.trace_id ?? run.id;\n // If we've already made a decision about this trace, follow it\n if (this.filteredPostUuids.has(traceId)) {\n continue;\n }\n // For new traces, apply sampling\n if (run.id === traceId) {\n if (this._shouldSample()) {\n sampled.push(run);\n }\n else {\n this.filteredPostUuids.add(traceId);\n }\n }\n else {\n // Child runs follow their trace's sampling decision\n sampled.push(run);\n }\n }\n return sampled;\n }\n }\n async _getBatchSizeLimitBytes() {\n const serverInfo = await this._ensureServerInfo();\n return (this.batchSizeBytesLimit ??\n serverInfo.batch_ingest_config?.size_limit_bytes ??\n exports.DEFAULT_UNCOMPRESSED_BATCH_SIZE_LIMIT_BYTES);\n }\n /**\n * Get the maximum number of operations to batch in a single request.\n */\n async _getBatchSizeLimit() {\n const serverInfo = await this._ensureServerInfo();\n return (this.batchSizeLimit ??\n serverInfo.batch_ingest_config?.size_limit ??\n DEFAULT_BATCH_SIZE_LIMIT);\n }\n async _getDatasetExamplesMultiPartSupport() {\n const serverInfo = await this._ensureServerInfo();\n return (serverInfo.instance_flags?.dataset_examples_multipart_enabled ?? false);\n }\n drainAutoBatchQueue({ batchSizeLimitBytes, batchSizeLimit, }) {\n const promises = [];\n while (this.autoBatchQueue.items.length > 0) {\n const [batch, done] = this.autoBatchQueue.pop({\n upToSizeBytes: batchSizeLimitBytes,\n upToSize: batchSizeLimit,\n });\n if (!batch.length) {\n done();\n break;\n }\n const batchesByDestination = batch.reduce((acc, item) => {\n const apiUrl = item.apiUrl ?? this.apiUrl;\n const apiKey = item.apiKey ?? this.apiKey;\n const isDefault = item.apiKey === this.apiKey && item.apiUrl === this.apiUrl;\n const batchKey = isDefault ? \"default\" : `${apiUrl}|${apiKey}`;\n if (!acc[batchKey]) {\n acc[batchKey] = [];\n }\n acc[batchKey].push(item);\n return acc;\n }, {});\n const batchPromises = [];\n for (const [batchKey, batch] of Object.entries(batchesByDestination)) {\n const batchPromise = this._processBatch(batch, {\n apiUrl: batchKey === \"default\" ? undefined : batchKey.split(\"|\")[0],\n apiKey: batchKey === \"default\" ? undefined : batchKey.split(\"|\")[1],\n });\n batchPromises.push(batchPromise);\n }\n // Wait for all batches to complete, then call the overall done callback\n const allBatchesPromise = Promise.all(batchPromises).finally(done);\n promises.push(allBatchesPromise);\n }\n return Promise.all(promises);\n }\n async _processBatch(batch, options) {\n if (!batch.length) {\n return;\n }\n // Calculate total batch size for queue tracking\n const batchSizeBytes = batch.reduce((sum, item) => sum + (item.size ?? 0), 0);\n try {\n if (this.langSmithToOTELTranslator !== undefined) {\n this._sendBatchToOTELTranslator(batch);\n }\n else {\n const ingestParams = {\n runCreates: batch\n .filter((item) => item.action === \"create\")\n .map((item) => item.item),\n runUpdates: batch\n .filter((item) => item.action === \"update\")\n .map((item) => item.item),\n };\n const serverInfo = await this._ensureServerInfo();\n if (serverInfo?.batch_ingest_config?.use_multipart_endpoint) {\n const useGzip = serverInfo?.instance_flags?.gzip_body_enabled;\n await this.multipartIngestRuns(ingestParams, {\n ...options,\n useGzip,\n sizeBytes: batchSizeBytes,\n });\n }\n else {\n await this.batchIngestRuns(ingestParams, {\n ...options,\n sizeBytes: batchSizeBytes,\n });\n }\n }\n }\n catch (e) {\n console.error(\"Error exporting batch:\", e);\n }\n }\n _sendBatchToOTELTranslator(batch) {\n if (this.langSmithToOTELTranslator !== undefined) {\n const otelContextMap = new Map();\n const operations = [];\n for (const item of batch) {\n if (item.item.id && item.otelContext) {\n otelContextMap.set(item.item.id, item.otelContext);\n if (item.action === \"create\") {\n operations.push({\n operation: \"post\",\n id: item.item.id,\n trace_id: item.item.trace_id ?? item.item.id,\n run: item.item,\n });\n }\n else {\n operations.push({\n operation: \"patch\",\n id: item.item.id,\n trace_id: item.item.trace_id ?? item.item.id,\n run: item.item,\n });\n }\n }\n }\n this.langSmithToOTELTranslator.exportBatch(operations, otelContextMap);\n }\n }\n async processRunOperation(item) {\n clearTimeout(this.autoBatchTimeout);\n this.autoBatchTimeout = undefined;\n item.item = mergeRuntimeEnvIntoRun(item.item, this.cachedLSEnvVarsForMetadata, this.omitTracedRuntimeInfo);\n const itemPromise = this.autoBatchQueue.push(item);\n if (this.manualFlushMode) {\n // Rely on manual flushing in serverless environments\n return itemPromise;\n }\n const sizeLimitBytes = await this._getBatchSizeLimitBytes();\n const sizeLimit = await this._getBatchSizeLimit();\n if (this.autoBatchQueue.sizeBytes > sizeLimitBytes ||\n this.autoBatchQueue.items.length > sizeLimit) {\n void this.drainAutoBatchQueue({\n batchSizeLimitBytes: sizeLimitBytes,\n batchSizeLimit: sizeLimit,\n });\n }\n if (this.autoBatchQueue.items.length > 0) {\n this.autoBatchTimeout = setTimeout(() => {\n this.autoBatchTimeout = undefined;\n void this.drainAutoBatchQueue({\n batchSizeLimitBytes: sizeLimitBytes,\n batchSizeLimit: sizeLimit,\n });\n }, this.autoBatchAggregationDelayMs);\n }\n return itemPromise;\n }\n async _getServerInfo() {\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/info`, {\n method: \"GET\",\n headers: { Accept: \"application/json\" },\n signal: AbortSignal.timeout(SERVER_INFO_REQUEST_TIMEOUT_MS),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"get server info\");\n return res;\n });\n const json = await response.json();\n if (this.debug) {\n console.log(\"\\n=== LangSmith Server Configuration ===\\n\" +\n JSON.stringify(json, null, 2) +\n \"\\n\");\n }\n return json;\n }\n async _ensureServerInfo() {\n if (this._getServerInfoPromise === undefined) {\n this._getServerInfoPromise = (async () => {\n if (this._serverInfo === undefined) {\n try {\n this._serverInfo = await this._getServerInfo();\n }\n catch (e) {\n console.warn(`[LANGSMITH]: Failed to fetch info on supported operations. Falling back to batch operations and default limits. Info: ${e.status ?? \"Unspecified status code\"} ${e.message}`);\n }\n }\n return this._serverInfo ?? {};\n })();\n }\n return this._getServerInfoPromise.then((serverInfo) => {\n if (this._serverInfo === undefined) {\n this._getServerInfoPromise = undefined;\n }\n return serverInfo;\n });\n }\n async _getSettings() {\n if (!this.settings) {\n this.settings = this._get(\"/settings\");\n }\n return await this.settings;\n }\n /**\n * Flushes current queued traces.\n */\n async flush() {\n const sizeLimitBytes = await this._getBatchSizeLimitBytes();\n const sizeLimit = await this._getBatchSizeLimit();\n await this.drainAutoBatchQueue({\n batchSizeLimitBytes: sizeLimitBytes,\n batchSizeLimit: sizeLimit,\n });\n }\n _cloneCurrentOTELContext() {\n const otel_trace = (0, otel_js_1.getOTELTrace)();\n const otel_context = (0, otel_js_1.getOTELContext)();\n if (this.langSmithToOTELTranslator !== undefined) {\n const currentSpan = otel_trace.getActiveSpan();\n if (currentSpan) {\n return otel_trace.setSpan(otel_context.active(), currentSpan);\n }\n }\n return undefined;\n }\n async createRun(run, options) {\n if (!this._filterForSampling([run]).length) {\n return;\n }\n const headers = {\n ...this.headers,\n \"Content-Type\": \"application/json\",\n };\n const session_name = run.project_name;\n delete run.project_name;\n const runCreate = await this.prepareRunCreateOrUpdateInputs({\n session_name,\n ...run,\n start_time: run.start_time ?? Date.now(),\n });\n if (this.autoBatchTracing &&\n runCreate.trace_id !== undefined &&\n runCreate.dotted_order !== undefined) {\n const otelContext = this._cloneCurrentOTELContext();\n void this.processRunOperation({\n action: \"create\",\n item: runCreate,\n otelContext,\n apiKey: options?.apiKey,\n apiUrl: options?.apiUrl,\n }).catch(console.error);\n return;\n }\n const mergedRunCreateParam = mergeRuntimeEnvIntoRun(runCreate, this.cachedLSEnvVarsForMetadata, this.omitTracedRuntimeInfo);\n if (options?.apiKey !== undefined) {\n headers[\"x-api-key\"] = options.apiKey;\n }\n if (options?.workspaceId !== undefined) {\n headers[\"x-tenant-id\"] = options.workspaceId;\n }\n const body = (0, index_js_2.serialize)(mergedRunCreateParam, `Creating run with id: ${mergedRunCreateParam.id}`);\n await this.caller.call(async () => {\n const res = await this._fetch(`${options?.apiUrl ?? this.apiUrl}/runs`, {\n method: \"POST\",\n headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"create run\", true);\n return res;\n });\n }\n /**\n * Batch ingest/upsert multiple runs in the Langsmith system.\n * @param runs\n */\n async batchIngestRuns({ runCreates, runUpdates, }, options) {\n if (runCreates === undefined && runUpdates === undefined) {\n return;\n }\n let preparedCreateParams = await Promise.all(runCreates?.map((create) => this.prepareRunCreateOrUpdateInputs(create)) ?? []);\n let preparedUpdateParams = await Promise.all(runUpdates?.map((update) => this.prepareRunCreateOrUpdateInputs(update)) ?? []);\n if (preparedCreateParams.length > 0 && preparedUpdateParams.length > 0) {\n const createById = preparedCreateParams.reduce((params, run) => {\n if (!run.id) {\n return params;\n }\n params[run.id] = run;\n return params;\n }, {});\n const standaloneUpdates = [];\n for (const updateParam of preparedUpdateParams) {\n if (updateParam.id !== undefined && createById[updateParam.id]) {\n createById[updateParam.id] = {\n ...createById[updateParam.id],\n ...updateParam,\n };\n }\n else {\n standaloneUpdates.push(updateParam);\n }\n }\n preparedCreateParams = Object.values(createById);\n preparedUpdateParams = standaloneUpdates;\n }\n const rawBatch = {\n post: preparedCreateParams,\n patch: preparedUpdateParams,\n };\n if (!rawBatch.post.length && !rawBatch.patch.length) {\n return;\n }\n const batchChunks = {\n post: [],\n patch: [],\n };\n for (const k of [\"post\", \"patch\"]) {\n const key = k;\n const batchItems = rawBatch[key].reverse();\n let batchItem = batchItems.pop();\n while (batchItem !== undefined) {\n // Type is wrong but this is a deprecated code path anyway\n batchChunks[key].push(batchItem);\n batchItem = batchItems.pop();\n }\n }\n if (batchChunks.post.length > 0 || batchChunks.patch.length > 0) {\n const runIds = batchChunks.post\n .map((item) => item.id)\n .concat(batchChunks.patch.map((item) => item.id))\n .join(\",\");\n await this._postBatchIngestRuns((0, index_js_2.serialize)(batchChunks, `Ingesting runs with ids: ${runIds}`), options);\n }\n }\n async _postBatchIngestRuns(body, options) {\n const headers = {\n ...this.headers,\n \"Content-Type\": \"application/json\",\n Accept: \"application/json\",\n };\n if (options?.apiKey !== undefined) {\n headers[\"x-api-key\"] = options.apiKey;\n }\n await this.batchIngestCaller.callWithOptions({ sizeBytes: options?.sizeBytes }, async () => {\n const res = await this._fetch(`${options?.apiUrl ?? this.apiUrl}/runs/batch`, {\n method: \"POST\",\n headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"batch create run\", true);\n return res;\n });\n }\n /**\n * Batch ingest/upsert multiple runs in the Langsmith system.\n * @param runs\n */\n async multipartIngestRuns({ runCreates, runUpdates, }, options) {\n if (runCreates === undefined && runUpdates === undefined) {\n return;\n }\n // transform and convert to dicts\n const allAttachments = {};\n let preparedCreateParams = [];\n for (const create of runCreates ?? []) {\n const preparedCreate = await this.prepareRunCreateOrUpdateInputs(create);\n if (preparedCreate.id !== undefined &&\n preparedCreate.attachments !== undefined) {\n allAttachments[preparedCreate.id] = preparedCreate.attachments;\n }\n delete preparedCreate.attachments;\n preparedCreateParams.push(preparedCreate);\n }\n let preparedUpdateParams = [];\n for (const update of runUpdates ?? []) {\n preparedUpdateParams.push(await this.prepareRunCreateOrUpdateInputs(update));\n }\n // require trace_id and dotted_order\n const invalidRunCreate = preparedCreateParams.find((runCreate) => {\n return (runCreate.trace_id === undefined || runCreate.dotted_order === undefined);\n });\n if (invalidRunCreate !== undefined) {\n throw new Error(`Multipart ingest requires \"trace_id\" and \"dotted_order\" to be set when creating a run`);\n }\n const invalidRunUpdate = preparedUpdateParams.find((runUpdate) => {\n return (runUpdate.trace_id === undefined || runUpdate.dotted_order === undefined);\n });\n if (invalidRunUpdate !== undefined) {\n throw new Error(`Multipart ingest requires \"trace_id\" and \"dotted_order\" to be set when updating a run`);\n }\n // combine post and patch dicts where possible\n if (preparedCreateParams.length > 0 && preparedUpdateParams.length > 0) {\n const createById = preparedCreateParams.reduce((params, run) => {\n if (!run.id) {\n return params;\n }\n params[run.id] = run;\n return params;\n }, {});\n const standaloneUpdates = [];\n for (const updateParam of preparedUpdateParams) {\n if (updateParam.id !== undefined && createById[updateParam.id]) {\n createById[updateParam.id] = {\n ...createById[updateParam.id],\n ...updateParam,\n };\n }\n else {\n standaloneUpdates.push(updateParam);\n }\n }\n preparedCreateParams = Object.values(createById);\n preparedUpdateParams = standaloneUpdates;\n }\n if (preparedCreateParams.length === 0 &&\n preparedUpdateParams.length === 0) {\n return;\n }\n // send the runs in multipart requests\n const accumulatedContext = [];\n const accumulatedParts = [];\n for (const [method, payloads] of [\n [\"post\", preparedCreateParams],\n [\"patch\", preparedUpdateParams],\n ]) {\n for (const originalPayload of payloads) {\n // collect fields to be sent as separate parts\n const { inputs, outputs, events, extra, error, serialized, attachments, ...payload } = originalPayload;\n const fields = { inputs, outputs, events, extra, error, serialized };\n // encode the main run payload\n const stringifiedPayload = (0, index_js_2.serialize)(payload, `Serializing for multipart ingestion of run with id: ${payload.id}`);\n accumulatedParts.push({\n name: `${method}.${payload.id}`,\n payload: new Blob([stringifiedPayload], {\n type: `application/json; length=${stringifiedPayload.length}`, // encoding=gzip\n }),\n });\n // encode the fields we collected\n for (const [key, value] of Object.entries(fields)) {\n if (value === undefined) {\n continue;\n }\n const stringifiedValue = (0, index_js_2.serialize)(value, `Serializing ${key} for multipart ingestion of run with id: ${payload.id}`);\n accumulatedParts.push({\n name: `${method}.${payload.id}.${key}`,\n payload: new Blob([stringifiedValue], {\n type: `application/json; length=${stringifiedValue.length}`,\n }),\n });\n }\n // encode the attachments\n if (payload.id !== undefined) {\n const attachments = allAttachments[payload.id];\n if (attachments) {\n delete allAttachments[payload.id];\n for (const [name, attachment] of Object.entries(attachments)) {\n let contentType;\n let content;\n if (Array.isArray(attachment)) {\n [contentType, content] = attachment;\n }\n else {\n contentType = attachment.mimeType;\n content = attachment.data;\n }\n // Validate that the attachment name doesn't contain a '.'\n if (name.includes(\".\")) {\n console.warn(`Skipping attachment '${name}' for run ${payload.id}: Invalid attachment name. ` +\n `Attachment names must not contain periods ('.'). Please rename the attachment and try again.`);\n continue;\n }\n accumulatedParts.push({\n name: `attachment.${payload.id}.${name}`,\n payload: new Blob([content], {\n type: `${contentType}; length=${content.byteLength}`,\n }),\n });\n }\n }\n }\n // compute context\n accumulatedContext.push(`trace=${payload.trace_id},id=${payload.id}`);\n }\n }\n await this._sendMultipartRequest(accumulatedParts, accumulatedContext.join(\"; \"), options);\n }\n async _createNodeFetchBody(parts, boundary) {\n // Create multipart form data manually using Blobs\n const chunks = [];\n for (const part of parts) {\n // Add field boundary\n chunks.push(new Blob([`--${boundary}\\r\\n`]));\n chunks.push(new Blob([\n `Content-Disposition: form-data; name=\"${part.name}\"\\r\\n`,\n `Content-Type: ${part.payload.type}\\r\\n\\r\\n`,\n ]));\n chunks.push(part.payload);\n chunks.push(new Blob([\"\\r\\n\"]));\n }\n // Add final boundary\n chunks.push(new Blob([`--${boundary}--\\r\\n`]));\n // Combine all chunks into a single Blob\n const body = new Blob(chunks);\n // Convert Blob to ArrayBuffer for compatibility\n const arrayBuffer = await body.arrayBuffer();\n return arrayBuffer;\n }\n async _createMultipartStream(parts, boundary) {\n const encoder = new TextEncoder();\n // Create a ReadableStream for streaming the multipart data\n // Only do special handling if we're using node-fetch\n const stream = new ReadableStream({\n async start(controller) {\n // Helper function to write a chunk to the stream\n const writeChunk = async (chunk) => {\n if (typeof chunk === \"string\") {\n controller.enqueue(encoder.encode(chunk));\n }\n else {\n controller.enqueue(chunk);\n }\n };\n // Write each part to the stream\n for (const part of parts) {\n // Write boundary and headers\n await writeChunk(`--${boundary}\\r\\n`);\n await writeChunk(`Content-Disposition: form-data; name=\"${part.name}\"\\r\\n`);\n await writeChunk(`Content-Type: ${part.payload.type}\\r\\n\\r\\n`);\n // Write the payload\n const payloadStream = part.payload.stream();\n const reader = payloadStream.getReader();\n try {\n let result;\n while (!(result = await reader.read()).done) {\n controller.enqueue(result.value);\n }\n }\n finally {\n reader.releaseLock();\n }\n await writeChunk(\"\\r\\n\");\n }\n // Write final boundary\n await writeChunk(`--${boundary}--\\r\\n`);\n controller.close();\n },\n });\n return stream;\n }\n async _sendMultipartRequest(parts, context, options) {\n // Create multipart form data boundary\n const boundary = \"----LangSmithFormBoundary\" + Math.random().toString(36).slice(2);\n const isNodeFetch = (0, fetch_js_1._globalFetchImplementationIsNodeFetch)();\n const buildBuffered = () => this._createNodeFetchBody(parts, boundary);\n const buildStream = () => this._createMultipartStream(parts, boundary);\n const sendWithRetry = async (bodyFactory) => {\n return this.batchIngestCaller.callWithOptions({ sizeBytes: options?.sizeBytes }, async () => {\n const body = await bodyFactory();\n const headers = {\n ...this.headers,\n \"Content-Type\": `multipart/form-data; boundary=${boundary}`,\n };\n if (options?.apiKey !== undefined) {\n headers[\"x-api-key\"] = options.apiKey;\n }\n let transformedBody = body;\n if (options?.useGzip &&\n typeof body === \"object\" &&\n \"pipeThrough\" in body) {\n transformedBody = body.pipeThrough(new CompressionStream(\"gzip\"));\n headers[\"Content-Encoding\"] = \"gzip\";\n }\n const response = await this._fetch(`${options?.apiUrl ?? this.apiUrl}/runs/multipart`, {\n method: \"POST\",\n headers,\n body: transformedBody,\n duplex: \"half\",\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(response, `Failed to send multipart request`, true);\n return response;\n });\n };\n try {\n let res;\n let streamedAttempt = false;\n // attempt stream only if not disabled and not using node-fetch or Bun\n if (!isNodeFetch &&\n !this.multipartStreamingDisabled &&\n (0, env_js_1.getEnv)() !== \"bun\") {\n streamedAttempt = true;\n res = await sendWithRetry(buildStream);\n }\n else {\n res = await sendWithRetry(buildBuffered);\n }\n // if stream fails, fallback to buffered body\n if ((!this.multipartStreamingDisabled || streamedAttempt) &&\n res.status === 422 &&\n (options?.apiUrl ?? this.apiUrl) !== DEFAULT_API_URL) {\n console.warn(`Streaming multipart upload to ${options?.apiUrl ?? this.apiUrl}/runs/multipart failed. ` +\n `This usually means the host does not support chunked uploads. ` +\n `Retrying with a buffered upload for operation \"${context}\".`);\n // Disable streaming for future requests\n this.multipartStreamingDisabled = true;\n // retry with fully-buffered body\n res = await sendWithRetry(buildBuffered);\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n }\n catch (e) {\n console.warn(`${e.message.trim()}\\n\\nContext: ${context}`);\n }\n }\n async updateRun(runId, run, options) {\n (0, _uuid_js_1.assertUuid)(runId);\n if (run.inputs) {\n run.inputs = await this.processInputs(run.inputs);\n }\n if (run.outputs) {\n run.outputs = await this.processOutputs(run.outputs);\n }\n // TODO: Untangle types\n const data = { ...run, id: runId };\n if (!this._filterForSampling([data], true).length) {\n return;\n }\n if (this.autoBatchTracing &&\n data.trace_id !== undefined &&\n data.dotted_order !== undefined) {\n const otelContext = this._cloneCurrentOTELContext();\n if (run.end_time !== undefined &&\n data.parent_run_id === undefined &&\n this.blockOnRootRunFinalization &&\n !this.manualFlushMode) {\n // Trigger batches as soon as a root trace ends and wait to ensure trace finishes\n // in serverless environments.\n await this.processRunOperation({\n action: \"update\",\n item: data,\n otelContext,\n apiKey: options?.apiKey,\n apiUrl: options?.apiUrl,\n }).catch(console.error);\n return;\n }\n else {\n void this.processRunOperation({\n action: \"update\",\n item: data,\n otelContext,\n apiKey: options?.apiKey,\n apiUrl: options?.apiUrl,\n }).catch(console.error);\n }\n return;\n }\n const headers = {\n ...this.headers,\n \"Content-Type\": \"application/json\",\n };\n if (options?.apiKey !== undefined) {\n headers[\"x-api-key\"] = options.apiKey;\n }\n if (options?.workspaceId !== undefined) {\n headers[\"x-tenant-id\"] = options.workspaceId;\n }\n const body = (0, index_js_2.serialize)(run, `Serializing payload to update run with id: ${runId}`);\n await this.caller.call(async () => {\n const res = await this._fetch(`${options?.apiUrl ?? this.apiUrl}/runs/${runId}`, {\n method: \"PATCH\",\n headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"update run\", true);\n return res;\n });\n }\n async readRun(runId, { loadChildRuns } = { loadChildRuns: false }) {\n (0, _uuid_js_1.assertUuid)(runId);\n let run = await this._get(`/runs/${runId}`);\n if (loadChildRuns) {\n run = await this._loadChildRuns(run);\n }\n return run;\n }\n async getRunUrl({ runId, run, projectOpts, }) {\n if (run !== undefined) {\n let sessionId;\n if (run.session_id) {\n sessionId = run.session_id;\n }\n else if (projectOpts?.projectName) {\n sessionId = (await this.readProject({ projectName: projectOpts?.projectName })).id;\n }\n else if (projectOpts?.projectId) {\n sessionId = projectOpts?.projectId;\n }\n else {\n const project = await this.readProject({\n projectName: (0, env_js_1.getLangSmithEnvironmentVariable)(\"PROJECT\") || \"default\",\n });\n sessionId = project.id;\n }\n const tenantId = await this._getTenantId();\n return `${this.getHostUrl()}/o/${tenantId}/projects/p/${sessionId}/r/${run.id}?poll=true`;\n }\n else if (runId !== undefined) {\n const run_ = await this.readRun(runId);\n if (!run_.app_path) {\n throw new Error(`Run ${runId} has no app_path`);\n }\n const baseUrl = this.getHostUrl();\n return `${baseUrl}${run_.app_path}`;\n }\n else {\n throw new Error(\"Must provide either runId or run\");\n }\n }\n async _loadChildRuns(run) {\n const childRuns = await toArray(this.listRuns({\n isRoot: false,\n projectId: run.session_id,\n traceId: run.trace_id,\n }));\n const treemap = {};\n const runs = {};\n // TODO: make dotted order required when the migration finishes\n childRuns.sort((a, b) => (a?.dotted_order ?? \"\").localeCompare(b?.dotted_order ?? \"\"));\n for (const childRun of childRuns) {\n if (childRun.parent_run_id === null ||\n childRun.parent_run_id === undefined) {\n throw new Error(`Child run ${childRun.id} has no parent`);\n }\n if (childRun.dotted_order?.startsWith(run.dotted_order ?? \"\") &&\n childRun.id !== run.id) {\n if (!(childRun.parent_run_id in treemap)) {\n treemap[childRun.parent_run_id] = [];\n }\n treemap[childRun.parent_run_id].push(childRun);\n runs[childRun.id] = childRun;\n }\n }\n run.child_runs = treemap[run.id] || [];\n for (const runId in treemap) {\n if (runId !== run.id) {\n runs[runId].child_runs = treemap[runId];\n }\n }\n return run;\n }\n /**\n * List runs from the LangSmith server.\n * @param projectId - The ID of the project to filter by.\n * @param projectName - The name of the project to filter by.\n * @param parentRunId - The ID of the parent run to filter by.\n * @param traceId - The ID of the trace to filter by.\n * @param referenceExampleId - The ID of the reference example to filter by.\n * @param startTime - The start time to filter by.\n * @param isRoot - Indicates whether to only return root runs.\n * @param runType - The run type to filter by.\n * @param error - Indicates whether to filter by error runs.\n * @param id - The ID of the run to filter by.\n * @param query - The query string to filter by.\n * @param filter - The filter string to apply to the run spans.\n * @param traceFilter - The filter string to apply on the root run of the trace.\n * @param treeFilter - The filter string to apply on other runs in the trace.\n * @param limit - The maximum number of runs to retrieve.\n * @returns {AsyncIterable<Run>} - The runs.\n *\n * @example\n * // List all runs in a project\n * const projectRuns = client.listRuns({ projectName: \"<your_project>\" });\n *\n * @example\n * // List LLM and Chat runs in the last 24 hours\n * const todaysLLMRuns = client.listRuns({\n * projectName: \"<your_project>\",\n * start_time: new Date(Date.now() - 24 * 60 * 60 * 1000),\n * run_type: \"llm\",\n * });\n *\n * @example\n * // List traces in a project\n * const rootRuns = client.listRuns({\n * projectName: \"<your_project>\",\n * execution_order: 1,\n * });\n *\n * @example\n * // List runs without errors\n * const correctRuns = client.listRuns({\n * projectName: \"<your_project>\",\n * error: false,\n * });\n *\n * @example\n * // List runs by run ID\n * const runIds = [\n * \"a36092d2-4ad5-4fb4-9c0d-0dba9a2ed836\",\n * \"9398e6be-964f-4aa4-8ae9-ad78cd4b7074\",\n * ];\n * const selectedRuns = client.listRuns({ run_ids: runIds });\n *\n * @example\n * // List all \"chain\" type runs that took more than 10 seconds and had `total_tokens` greater than 5000\n * const chainRuns = client.listRuns({\n * projectName: \"<your_project>\",\n * filter: 'and(eq(run_type, \"chain\"), gt(latency, 10), gt(total_tokens, 5000))',\n * });\n *\n * @example\n * // List all runs called \"extractor\" whose root of the trace was assigned feedback \"user_score\" score of 1\n * const goodExtractorRuns = client.listRuns({\n * projectName: \"<your_project>\",\n * filter: 'eq(name, \"extractor\")',\n * traceFilter: 'and(eq(feedback_key, \"user_score\"), eq(feedback_score, 1))',\n * });\n *\n * @example\n * // List all runs that started after a specific timestamp and either have \"error\" not equal to null or a \"Correctness\" feedback score equal to 0\n * const complexRuns = client.listRuns({\n * projectName: \"<your_project>\",\n * filter: 'and(gt(start_time, \"2023-07-15T12:34:56Z\"), or(neq(error, null), and(eq(feedback_key, \"Correctness\"), eq(feedback_score, 0.0))))',\n * });\n *\n * @example\n * // List all runs where `tags` include \"experimental\" or \"beta\" and `latency` is greater than 2 seconds\n * const taggedRuns = client.listRuns({\n * projectName: \"<your_project>\",\n * filter: 'and(or(has(tags, \"experimental\"), has(tags, \"beta\")), gt(latency, 2))',\n * });\n */\n async *listRuns(props) {\n const { projectId, projectName, parentRunId, traceId, referenceExampleId, startTime, executionOrder, isRoot, runType, error, id, query, filter, traceFilter, treeFilter, limit, select, order, } = props;\n let projectIds = [];\n if (projectId) {\n projectIds = Array.isArray(projectId) ? projectId : [projectId];\n }\n if (projectName) {\n const projectNames = Array.isArray(projectName)\n ? projectName\n : [projectName];\n const projectIds_ = await Promise.all(projectNames.map((name) => this.readProject({ projectName: name }).then((project) => project.id)));\n projectIds.push(...projectIds_);\n }\n const default_select = [\n \"app_path\",\n \"completion_cost\",\n \"completion_tokens\",\n \"dotted_order\",\n \"end_time\",\n \"error\",\n \"events\",\n \"extra\",\n \"feedback_stats\",\n \"first_token_time\",\n \"id\",\n \"inputs\",\n \"name\",\n \"outputs\",\n \"parent_run_id\",\n \"parent_run_ids\",\n \"prompt_cost\",\n \"prompt_tokens\",\n \"reference_example_id\",\n \"run_type\",\n \"session_id\",\n \"start_time\",\n \"status\",\n \"tags\",\n \"total_cost\",\n \"total_tokens\",\n \"trace_id\",\n ];\n const body = {\n session: projectIds.length ? projectIds : null,\n run_type: runType,\n reference_example: referenceExampleId,\n query,\n filter,\n trace_filter: traceFilter,\n tree_filter: treeFilter,\n execution_order: executionOrder,\n parent_run: parentRunId,\n start_time: startTime ? startTime.toISOString() : null,\n error,\n id,\n limit,\n trace: traceId,\n select: select ? select : default_select,\n is_root: isRoot,\n order,\n };\n if (body.select.includes(\"child_run_ids\")) {\n (0, warn_js_1.warnOnce)(\"Deprecated: 'child_run_ids' in the listRuns select parameter is deprecated and will be removed in a future version.\");\n }\n let runsYielded = 0;\n for await (const runs of this._getCursorPaginatedList(\"/runs/query\", body)) {\n if (limit) {\n if (runsYielded >= limit) {\n break;\n }\n if (runs.length + runsYielded > limit) {\n const newRuns = runs.slice(0, limit - runsYielded);\n yield* newRuns;\n break;\n }\n runsYielded += runs.length;\n yield* runs;\n }\n else {\n yield* runs;\n }\n }\n }\n async *listGroupRuns(props) {\n const { projectId, projectName, groupBy, filter, startTime, endTime, limit, offset, } = props;\n const sessionId = projectId || (await this.readProject({ projectName })).id;\n const baseBody = {\n session_id: sessionId,\n group_by: groupBy,\n filter,\n start_time: startTime ? startTime.toISOString() : null,\n end_time: endTime ? endTime.toISOString() : null,\n limit: Number(limit) || 100,\n };\n let currentOffset = Number(offset) || 0;\n const path = \"/runs/group\";\n const url = `${this.apiUrl}${path}`;\n while (true) {\n const currentBody = {\n ...baseBody,\n offset: currentOffset,\n };\n // Remove undefined values from the payload\n const filteredPayload = Object.fromEntries(Object.entries(currentBody).filter(([_, value]) => value !== undefined));\n const body = JSON.stringify(filteredPayload);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(url, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, `Failed to fetch ${path}`);\n return res;\n });\n const items = await response.json();\n const { groups, total } = items;\n if (groups.length === 0) {\n break;\n }\n for (const thread of groups) {\n yield thread;\n }\n currentOffset += groups.length;\n if (currentOffset >= total) {\n break;\n }\n }\n }\n async getRunStats({ id, trace, parentRun, runType, projectNames, projectIds, referenceExampleIds, startTime, endTime, error, query, filter, traceFilter, treeFilter, isRoot, dataSourceType, }) {\n let projectIds_ = projectIds || [];\n if (projectNames) {\n projectIds_ = [\n ...(projectIds || []),\n ...(await Promise.all(projectNames.map((name) => this.readProject({ projectName: name }).then((project) => project.id)))),\n ];\n }\n const payload = {\n id,\n trace,\n parent_run: parentRun,\n run_type: runType,\n session: projectIds_,\n reference_example: referenceExampleIds,\n start_time: startTime,\n end_time: endTime,\n error,\n query,\n filter,\n trace_filter: traceFilter,\n tree_filter: treeFilter,\n is_root: isRoot,\n data_source_type: dataSourceType,\n };\n // Remove undefined values from the payload\n const filteredPayload = Object.fromEntries(Object.entries(payload).filter(([_, value]) => value !== undefined));\n const body = JSON.stringify(filteredPayload);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/runs/stats`, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"get run stats\");\n return res;\n });\n const result = await response.json();\n return result;\n }\n async shareRun(runId, { shareId } = {}) {\n const data = {\n run_id: runId,\n share_token: shareId || uuid.v4(),\n };\n (0, _uuid_js_1.assertUuid)(runId);\n const body = JSON.stringify(data);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/runs/${runId}/share`, {\n method: \"PUT\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"share run\");\n return res;\n });\n const result = await response.json();\n if (result === null || !(\"share_token\" in result)) {\n throw new Error(\"Invalid response from server\");\n }\n return `${this.getHostUrl()}/public/${result[\"share_token\"]}/r`;\n }\n async unshareRun(runId) {\n (0, _uuid_js_1.assertUuid)(runId);\n await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/runs/${runId}/share`, {\n method: \"DELETE\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"unshare run\", true);\n return res;\n });\n }\n async readRunSharedLink(runId) {\n (0, _uuid_js_1.assertUuid)(runId);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/runs/${runId}/share`, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"read run shared link\");\n return res;\n });\n const result = await response.json();\n if (result === null || !(\"share_token\" in result)) {\n return undefined;\n }\n return `${this.getHostUrl()}/public/${result[\"share_token\"]}/r`;\n }\n async listSharedRuns(shareToken, { runIds, } = {}) {\n const queryParams = new URLSearchParams({\n share_token: shareToken,\n });\n if (runIds !== undefined) {\n for (const runId of runIds) {\n queryParams.append(\"id\", runId);\n }\n }\n (0, _uuid_js_1.assertUuid)(shareToken);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/public/${shareToken}/runs${queryParams}`, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"list shared runs\");\n return res;\n });\n const runs = await response.json();\n return runs;\n }\n async readDatasetSharedSchema(datasetId, datasetName) {\n if (!datasetId && !datasetName) {\n throw new Error(\"Either datasetId or datasetName must be given\");\n }\n if (!datasetId) {\n const dataset = await this.readDataset({ datasetName });\n datasetId = dataset.id;\n }\n (0, _uuid_js_1.assertUuid)(datasetId);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/datasets/${datasetId}/share`, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"read dataset shared schema\");\n return res;\n });\n const shareSchema = await response.json();\n shareSchema.url = `${this.getHostUrl()}/public/${shareSchema.share_token}/d`;\n return shareSchema;\n }\n async shareDataset(datasetId, datasetName) {\n if (!datasetId && !datasetName) {\n throw new Error(\"Either datasetId or datasetName must be given\");\n }\n if (!datasetId) {\n const dataset = await this.readDataset({ datasetName });\n datasetId = dataset.id;\n }\n const data = {\n dataset_id: datasetId,\n };\n (0, _uuid_js_1.assertUuid)(datasetId);\n const body = JSON.stringify(data);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/datasets/${datasetId}/share`, {\n method: \"PUT\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"share dataset\");\n return res;\n });\n const shareSchema = await response.json();\n shareSchema.url = `${this.getHostUrl()}/public/${shareSchema.share_token}/d`;\n return shareSchema;\n }\n async unshareDataset(datasetId) {\n (0, _uuid_js_1.assertUuid)(datasetId);\n await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/datasets/${datasetId}/share`, {\n method: \"DELETE\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"unshare dataset\", true);\n return res;\n });\n }\n async readSharedDataset(shareToken) {\n (0, _uuid_js_1.assertUuid)(shareToken);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/public/${shareToken}/datasets`, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"read shared dataset\");\n return res;\n });\n const dataset = await response.json();\n return dataset;\n }\n /**\n * Get shared examples.\n *\n * @param {string} shareToken The share token to get examples for. A share token is the UUID (or LangSmith URL, including UUID) generated when explicitly marking an example as public.\n * @param {Object} [options] Additional options for listing the examples.\n * @param {string[] | undefined} [options.exampleIds] A list of example IDs to filter by.\n * @returns {Promise<Example[]>} The shared examples.\n */\n async listSharedExamples(shareToken, options) {\n const params = {};\n if (options?.exampleIds) {\n params.id = options.exampleIds;\n }\n const urlParams = new URLSearchParams();\n Object.entries(params).forEach(([key, value]) => {\n if (Array.isArray(value)) {\n value.forEach((v) => urlParams.append(key, v));\n }\n else {\n urlParams.append(key, value);\n }\n });\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/public/${shareToken}/examples?${urlParams.toString()}`, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"list shared examples\");\n return res;\n });\n const result = await response.json();\n if (!response.ok) {\n if (\"detail\" in result) {\n throw new Error(`Failed to list shared examples.\\nStatus: ${response.status}\\nMessage: ${Array.isArray(result.detail)\n ? result.detail.join(\"\\n\")\n : \"Unspecified error\"}`);\n }\n throw new Error(`Failed to list shared examples: ${response.status} ${response.statusText}`);\n }\n return result.map((example) => ({\n ...example,\n _hostUrl: this.getHostUrl(),\n }));\n }\n async createProject({ projectName, description = null, metadata = null, upsert = false, projectExtra = null, referenceDatasetId = null, }) {\n const upsert_ = upsert ? `?upsert=true` : \"\";\n const endpoint = `${this.apiUrl}/sessions${upsert_}`;\n const extra = projectExtra || {};\n if (metadata) {\n extra[\"metadata\"] = metadata;\n }\n const body = {\n name: projectName,\n extra,\n description,\n };\n if (referenceDatasetId !== null) {\n body[\"reference_dataset_id\"] = referenceDatasetId;\n }\n const serializedBody = JSON.stringify(body);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(endpoint, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body: serializedBody,\n });\n await (0, error_js_1.raiseForStatus)(res, \"create project\");\n return res;\n });\n const result = await response.json();\n return result;\n }\n async updateProject(projectId, { name = null, description = null, metadata = null, projectExtra = null, endTime = null, }) {\n const endpoint = `${this.apiUrl}/sessions/${projectId}`;\n let extra = projectExtra;\n if (metadata) {\n extra = { ...(extra || {}), metadata };\n }\n const body = JSON.stringify({\n name,\n extra,\n description,\n end_time: endTime ? new Date(endTime).toISOString() : null,\n });\n const response = await this.caller.call(async () => {\n const res = await this._fetch(endpoint, {\n method: \"PATCH\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"update project\");\n return res;\n });\n const result = await response.json();\n return result;\n }\n async hasProject({ projectId, projectName, }) {\n // TODO: Add a head request\n let path = \"/sessions\";\n const params = new URLSearchParams();\n if (projectId !== undefined && projectName !== undefined) {\n throw new Error(\"Must provide either projectName or projectId, not both\");\n }\n else if (projectId !== undefined) {\n (0, _uuid_js_1.assertUuid)(projectId);\n path += `/${projectId}`;\n }\n else if (projectName !== undefined) {\n params.append(\"name\", projectName);\n }\n else {\n throw new Error(\"Must provide projectName or projectId\");\n }\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}${path}?${params}`, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"has project\");\n return res;\n });\n // consume the response body to release the connection\n // https://undici.nodejs.org/#/?id=garbage-collection\n try {\n const result = await response.json();\n if (!response.ok) {\n return false;\n }\n // If it's OK and we're querying by name, need to check the list is not empty\n if (Array.isArray(result)) {\n return result.length > 0;\n }\n // projectId querying\n return true;\n }\n catch (e) {\n return false;\n }\n }\n async readProject({ projectId, projectName, includeStats, }) {\n let path = \"/sessions\";\n const params = new URLSearchParams();\n if (projectId !== undefined && projectName !== undefined) {\n throw new Error(\"Must provide either projectName or projectId, not both\");\n }\n else if (projectId !== undefined) {\n (0, _uuid_js_1.assertUuid)(projectId);\n path += `/${projectId}`;\n }\n else if (projectName !== undefined) {\n params.append(\"name\", projectName);\n }\n else {\n throw new Error(\"Must provide projectName or projectId\");\n }\n if (includeStats !== undefined) {\n params.append(\"include_stats\", includeStats.toString());\n }\n const response = await this._get(path, params);\n let result;\n if (Array.isArray(response)) {\n if (response.length === 0) {\n throw new Error(`Project[id=${projectId}, name=${projectName}] not found`);\n }\n result = response[0];\n }\n else {\n result = response;\n }\n return result;\n }\n async getProjectUrl({ projectId, projectName, }) {\n if (projectId === undefined && projectName === undefined) {\n throw new Error(\"Must provide either projectName or projectId\");\n }\n const project = await this.readProject({ projectId, projectName });\n const tenantId = await this._getTenantId();\n return `${this.getHostUrl()}/o/${tenantId}/projects/p/${project.id}`;\n }\n async getDatasetUrl({ datasetId, datasetName, }) {\n if (datasetId === undefined && datasetName === undefined) {\n throw new Error(\"Must provide either datasetName or datasetId\");\n }\n const dataset = await this.readDataset({ datasetId, datasetName });\n const tenantId = await this._getTenantId();\n return `${this.getHostUrl()}/o/${tenantId}/datasets/${dataset.id}`;\n }\n async _getTenantId() {\n if (this._tenantId !== null) {\n return this._tenantId;\n }\n const queryParams = new URLSearchParams({ limit: \"1\" });\n for await (const projects of this._getPaginated(\"/sessions\", queryParams)) {\n this._tenantId = projects[0].tenant_id;\n return projects[0].tenant_id;\n }\n throw new Error(\"No projects found to resolve tenant.\");\n }\n async *listProjects({ projectIds, name, nameContains, referenceDatasetId, referenceDatasetName, includeStats, datasetVersion, referenceFree, metadata, } = {}) {\n const params = new URLSearchParams();\n if (projectIds !== undefined) {\n for (const projectId of projectIds) {\n params.append(\"id\", projectId);\n }\n }\n if (name !== undefined) {\n params.append(\"name\", name);\n }\n if (nameContains !== undefined) {\n params.append(\"name_contains\", nameContains);\n }\n if (referenceDatasetId !== undefined) {\n params.append(\"reference_dataset\", referenceDatasetId);\n }\n else if (referenceDatasetName !== undefined) {\n const dataset = await this.readDataset({\n datasetName: referenceDatasetName,\n });\n params.append(\"reference_dataset\", dataset.id);\n }\n if (includeStats !== undefined) {\n params.append(\"include_stats\", includeStats.toString());\n }\n if (datasetVersion !== undefined) {\n params.append(\"dataset_version\", datasetVersion);\n }\n if (referenceFree !== undefined) {\n params.append(\"reference_free\", referenceFree.toString());\n }\n if (metadata !== undefined) {\n params.append(\"metadata\", JSON.stringify(metadata));\n }\n for await (const projects of this._getPaginated(\"/sessions\", params)) {\n yield* projects;\n }\n }\n async deleteProject({ projectId, projectName, }) {\n let projectId_;\n if (projectId === undefined && projectName === undefined) {\n throw new Error(\"Must provide projectName or projectId\");\n }\n else if (projectId !== undefined && projectName !== undefined) {\n throw new Error(\"Must provide either projectName or projectId, not both\");\n }\n else if (projectId === undefined) {\n projectId_ = (await this.readProject({ projectName })).id;\n }\n else {\n projectId_ = projectId;\n }\n (0, _uuid_js_1.assertUuid)(projectId_);\n await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/sessions/${projectId_}`, {\n method: \"DELETE\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, `delete session ${projectId_} (${projectName})`, true);\n return res;\n });\n }\n async uploadCsv({ csvFile, fileName, inputKeys, outputKeys, description, dataType, name, }) {\n const url = `${this.apiUrl}/datasets/upload`;\n const formData = new FormData();\n formData.append(\"file\", csvFile, fileName);\n inputKeys.forEach((key) => {\n formData.append(\"input_keys\", key);\n });\n outputKeys.forEach((key) => {\n formData.append(\"output_keys\", key);\n });\n if (description) {\n formData.append(\"description\", description);\n }\n if (dataType) {\n formData.append(\"data_type\", dataType);\n }\n if (name) {\n formData.append(\"name\", name);\n }\n const response = await this.caller.call(async () => {\n const res = await this._fetch(url, {\n method: \"POST\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body: formData,\n });\n await (0, error_js_1.raiseForStatus)(res, \"upload CSV\");\n return res;\n });\n const result = await response.json();\n return result;\n }\n async createDataset(name, { description, dataType, inputsSchema, outputsSchema, metadata, } = {}) {\n const body = {\n name,\n description,\n extra: metadata ? { metadata } : undefined,\n };\n if (dataType) {\n body.data_type = dataType;\n }\n if (inputsSchema) {\n body.inputs_schema_definition = inputsSchema;\n }\n if (outputsSchema) {\n body.outputs_schema_definition = outputsSchema;\n }\n const serializedBody = JSON.stringify(body);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/datasets`, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body: serializedBody,\n });\n await (0, error_js_1.raiseForStatus)(res, \"create dataset\");\n return res;\n });\n const result = await response.json();\n return result;\n }\n async readDataset({ datasetId, datasetName, }) {\n let path = \"/datasets\";\n // limit to 1 result\n const params = new URLSearchParams({ limit: \"1\" });\n if (datasetId && datasetName) {\n throw new Error(\"Must provide either datasetName or datasetId, not both\");\n }\n else if (datasetId) {\n (0, _uuid_js_1.assertUuid)(datasetId);\n path += `/${datasetId}`;\n }\n else if (datasetName) {\n params.append(\"name\", datasetName);\n }\n else {\n throw new Error(\"Must provide datasetName or datasetId\");\n }\n const response = await this._get(path, params);\n let result;\n if (Array.isArray(response)) {\n if (response.length === 0) {\n throw new Error(`Dataset[id=${datasetId}, name=${datasetName}] not found`);\n }\n result = response[0];\n }\n else {\n result = response;\n }\n return result;\n }\n async hasDataset({ datasetId, datasetName, }) {\n try {\n await this.readDataset({ datasetId, datasetName });\n return true;\n }\n catch (e) {\n if (\n // eslint-disable-next-line no-instanceof/no-instanceof\n e instanceof Error &&\n e.message.toLocaleLowerCase().includes(\"not found\")) {\n return false;\n }\n throw e;\n }\n }\n async diffDatasetVersions({ datasetId, datasetName, fromVersion, toVersion, }) {\n let datasetId_ = datasetId;\n if (datasetId_ === undefined && datasetName === undefined) {\n throw new Error(\"Must provide either datasetName or datasetId\");\n }\n else if (datasetId_ !== undefined && datasetName !== undefined) {\n throw new Error(\"Must provide either datasetName or datasetId, not both\");\n }\n else if (datasetId_ === undefined) {\n const dataset = await this.readDataset({ datasetName });\n datasetId_ = dataset.id;\n }\n const urlParams = new URLSearchParams({\n from_version: typeof fromVersion === \"string\"\n ? fromVersion\n : fromVersion.toISOString(),\n to_version: typeof toVersion === \"string\" ? toVersion : toVersion.toISOString(),\n });\n const response = await this._get(`/datasets/${datasetId_}/versions/diff`, urlParams);\n return response;\n }\n async readDatasetOpenaiFinetuning({ datasetId, datasetName, }) {\n const path = \"/datasets\";\n if (datasetId !== undefined) {\n // do nothing\n }\n else if (datasetName !== undefined) {\n datasetId = (await this.readDataset({ datasetName })).id;\n }\n else {\n throw new Error(\"Must provide either datasetName or datasetId\");\n }\n const response = await this._getResponse(`${path}/${datasetId}/openai_ft`);\n const datasetText = await response.text();\n const dataset = datasetText\n .trim()\n .split(\"\\n\")\n .map((line) => JSON.parse(line));\n return dataset;\n }\n async *listDatasets({ limit = 100, offset = 0, datasetIds, datasetName, datasetNameContains, metadata, } = {}) {\n const path = \"/datasets\";\n const params = new URLSearchParams({\n limit: limit.toString(),\n offset: offset.toString(),\n });\n if (datasetIds !== undefined) {\n for (const id_ of datasetIds) {\n params.append(\"id\", id_);\n }\n }\n if (datasetName !== undefined) {\n params.append(\"name\", datasetName);\n }\n if (datasetNameContains !== undefined) {\n params.append(\"name_contains\", datasetNameContains);\n }\n if (metadata !== undefined) {\n params.append(\"metadata\", JSON.stringify(metadata));\n }\n for await (const datasets of this._getPaginated(path, params)) {\n yield* datasets;\n }\n }\n /**\n * Update a dataset\n * @param props The dataset details to update\n * @returns The updated dataset\n */\n async updateDataset(props) {\n const { datasetId, datasetName, ...update } = props;\n if (!datasetId && !datasetName) {\n throw new Error(\"Must provide either datasetName or datasetId\");\n }\n const _datasetId = datasetId ?? (await this.readDataset({ datasetName })).id;\n (0, _uuid_js_1.assertUuid)(_datasetId);\n const body = JSON.stringify(update);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/datasets/${_datasetId}`, {\n method: \"PATCH\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"update dataset\");\n return res;\n });\n return (await response.json());\n }\n /**\n * Updates a tag on a dataset.\n *\n * If the tag is already assigned to a different version of this dataset,\n * the tag will be moved to the new version. The as_of parameter is used to\n * determine which version of the dataset to apply the new tags to.\n *\n * It must be an exact version of the dataset to succeed. You can\n * use the \"readDatasetVersion\" method to find the exact version\n * to apply the tags to.\n * @param params.datasetId The ID of the dataset to update. Must be provided if \"datasetName\" is not provided.\n * @param params.datasetName The name of the dataset to update. Must be provided if \"datasetId\" is not provided.\n * @param params.asOf The timestamp of the dataset to apply the new tags to.\n * @param params.tag The new tag to apply to the dataset.\n */\n async updateDatasetTag(props) {\n const { datasetId, datasetName, asOf, tag } = props;\n if (!datasetId && !datasetName) {\n throw new Error(\"Must provide either datasetName or datasetId\");\n }\n const _datasetId = datasetId ?? (await this.readDataset({ datasetName })).id;\n (0, _uuid_js_1.assertUuid)(_datasetId);\n const body = JSON.stringify({\n as_of: typeof asOf === \"string\" ? asOf : asOf.toISOString(),\n tag,\n });\n await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/datasets/${_datasetId}/tags`, {\n method: \"PUT\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"update dataset tags\", true);\n return res;\n });\n }\n async deleteDataset({ datasetId, datasetName, }) {\n let path = \"/datasets\";\n let datasetId_ = datasetId;\n if (datasetId !== undefined && datasetName !== undefined) {\n throw new Error(\"Must provide either datasetName or datasetId, not both\");\n }\n else if (datasetName !== undefined) {\n const dataset = await this.readDataset({ datasetName });\n datasetId_ = dataset.id;\n }\n if (datasetId_ !== undefined) {\n (0, _uuid_js_1.assertUuid)(datasetId_);\n path += `/${datasetId_}`;\n }\n else {\n throw new Error(\"Must provide datasetName or datasetId\");\n }\n await this.caller.call(async () => {\n const res = await this._fetch(this.apiUrl + path, {\n method: \"DELETE\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, `delete ${path}`, true);\n return res;\n });\n }\n async indexDataset({ datasetId, datasetName, tag, }) {\n let datasetId_ = datasetId;\n if (!datasetId_ && !datasetName) {\n throw new Error(\"Must provide either datasetName or datasetId\");\n }\n else if (datasetId_ && datasetName) {\n throw new Error(\"Must provide either datasetName or datasetId, not both\");\n }\n else if (!datasetId_) {\n const dataset = await this.readDataset({ datasetName });\n datasetId_ = dataset.id;\n }\n (0, _uuid_js_1.assertUuid)(datasetId_);\n const data = {\n tag: tag,\n };\n const body = JSON.stringify(data);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/datasets/${datasetId_}/index`, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"index dataset\");\n return res;\n });\n await response.json();\n }\n /**\n * Lets you run a similarity search query on a dataset.\n *\n * Requires the dataset to be indexed. Please see the `indexDataset` method to set up indexing.\n *\n * @param inputs The input on which to run the similarity search. Must have the\n * same schema as the dataset.\n *\n * @param datasetId The dataset to search for similar examples.\n *\n * @param limit The maximum number of examples to return. Will return the top `limit` most\n * similar examples in order of most similar to least similar. If no similar\n * examples are found, random examples will be returned.\n *\n * @param filter A filter string to apply to the search. Only examples will be returned that\n * match the filter string. Some examples of filters\n *\n * - eq(metadata.mykey, \"value\")\n * - and(neq(metadata.my.nested.key, \"value\"), neq(metadata.mykey, \"value\"))\n * - or(eq(metadata.mykey, \"value\"), eq(metadata.mykey, \"othervalue\"))\n *\n * @returns A list of similar examples.\n *\n *\n * @example\n * dataset_id = \"123e4567-e89b-12d3-a456-426614174000\"\n * inputs = {\"text\": \"How many people live in Berlin?\"}\n * limit = 5\n * examples = await client.similarExamples(inputs, dataset_id, limit)\n */\n async similarExamples(inputs, datasetId, limit, { filter, } = {}) {\n const data = {\n limit: limit,\n inputs: inputs,\n };\n if (filter !== undefined) {\n data[\"filter\"] = filter;\n }\n (0, _uuid_js_1.assertUuid)(datasetId);\n const body = JSON.stringify(data);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/datasets/${datasetId}/search`, {\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n method: \"POST\",\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"fetch similar examples\");\n return res;\n });\n const result = await response.json();\n return result[\"examples\"];\n }\n async createExample(inputsOrUpdate, outputs, options) {\n if (isExampleCreate(inputsOrUpdate)) {\n if (outputs !== undefined || options !== undefined) {\n throw new Error(\"Cannot provide outputs or options when using ExampleCreate object\");\n }\n }\n let datasetId_ = outputs ? options?.datasetId : inputsOrUpdate.dataset_id;\n const datasetName_ = outputs\n ? options?.datasetName\n : inputsOrUpdate.dataset_name;\n if (datasetId_ === undefined && datasetName_ === undefined) {\n throw new Error(\"Must provide either datasetName or datasetId\");\n }\n else if (datasetId_ !== undefined && datasetName_ !== undefined) {\n throw new Error(\"Must provide either datasetName or datasetId, not both\");\n }\n else if (datasetId_ === undefined) {\n const dataset = await this.readDataset({ datasetName: datasetName_ });\n datasetId_ = dataset.id;\n }\n const createdAt_ = (outputs ? options?.createdAt : inputsOrUpdate.created_at) || new Date();\n let data;\n if (!isExampleCreate(inputsOrUpdate)) {\n data = {\n inputs: inputsOrUpdate,\n outputs,\n created_at: createdAt_?.toISOString(),\n id: options?.exampleId,\n metadata: options?.metadata,\n split: options?.split,\n source_run_id: options?.sourceRunId,\n use_source_run_io: options?.useSourceRunIO,\n use_source_run_attachments: options?.useSourceRunAttachments,\n attachments: options?.attachments,\n };\n }\n else {\n data = inputsOrUpdate;\n }\n const response = await this._uploadExamplesMultipart(datasetId_, [data]);\n const example = await this.readExample(response.example_ids?.[0] ?? uuid.v4());\n return example;\n }\n async createExamples(propsOrUploads) {\n if (Array.isArray(propsOrUploads)) {\n if (propsOrUploads.length === 0) {\n return [];\n }\n const uploads = propsOrUploads;\n let datasetId_ = uploads[0].dataset_id;\n const datasetName_ = uploads[0].dataset_name;\n if (datasetId_ === undefined && datasetName_ === undefined) {\n throw new Error(\"Must provide either datasetName or datasetId\");\n }\n else if (datasetId_ !== undefined && datasetName_ !== undefined) {\n throw new Error(\"Must provide either datasetName or datasetId, not both\");\n }\n else if (datasetId_ === undefined) {\n const dataset = await this.readDataset({ datasetName: datasetName_ });\n datasetId_ = dataset.id;\n }\n const response = await this._uploadExamplesMultipart(datasetId_, uploads);\n const examples = await Promise.all(response.example_ids.map((id) => this.readExample(id)));\n return examples;\n }\n const { inputs, outputs, metadata, splits, sourceRunIds, useSourceRunIOs, useSourceRunAttachments, attachments, exampleIds, datasetId, datasetName, } = propsOrUploads;\n if (inputs === undefined) {\n throw new Error(\"Must provide inputs when using legacy parameters\");\n }\n let datasetId_ = datasetId;\n const datasetName_ = datasetName;\n if (datasetId_ === undefined && datasetName_ === undefined) {\n throw new Error(\"Must provide either datasetName or datasetId\");\n }\n else if (datasetId_ !== undefined && datasetName_ !== undefined) {\n throw new Error(\"Must provide either datasetName or datasetId, not both\");\n }\n else if (datasetId_ === undefined) {\n const dataset = await this.readDataset({ datasetName: datasetName_ });\n datasetId_ = dataset.id;\n }\n const formattedExamples = inputs.map((input, idx) => {\n return {\n dataset_id: datasetId_,\n inputs: input,\n outputs: outputs?.[idx],\n metadata: metadata?.[idx],\n split: splits?.[idx],\n id: exampleIds?.[idx],\n attachments: attachments?.[idx],\n source_run_id: sourceRunIds?.[idx],\n use_source_run_io: useSourceRunIOs?.[idx],\n use_source_run_attachments: useSourceRunAttachments?.[idx],\n };\n });\n const response = await this._uploadExamplesMultipart(datasetId_, formattedExamples);\n const examples = await Promise.all(response.example_ids.map((id) => this.readExample(id)));\n return examples;\n }\n async createLLMExample(input, generation, options) {\n return this.createExample({ input }, { output: generation }, options);\n }\n async createChatExample(input, generations, options) {\n const finalInput = input.map((message) => {\n if ((0, messages_js_1.isLangChainMessage)(message)) {\n return (0, messages_js_1.convertLangChainMessageToExample)(message);\n }\n return message;\n });\n const finalOutput = (0, messages_js_1.isLangChainMessage)(generations)\n ? (0, messages_js_1.convertLangChainMessageToExample)(generations)\n : generations;\n return this.createExample({ input: finalInput }, { output: finalOutput }, options);\n }\n async readExample(exampleId) {\n (0, _uuid_js_1.assertUuid)(exampleId);\n const path = `/examples/${exampleId}`;\n const rawExample = await this._get(path);\n const { attachment_urls, ...rest } = rawExample;\n const example = rest;\n if (attachment_urls) {\n example.attachments = Object.entries(attachment_urls).reduce((acc, [key, value]) => {\n acc[key.slice(\"attachment.\".length)] = {\n presigned_url: value.presigned_url,\n mime_type: value.mime_type,\n };\n return acc;\n }, {});\n }\n return example;\n }\n async *listExamples({ datasetId, datasetName, exampleIds, asOf, splits, inlineS3Urls, metadata, limit, offset, filter, includeAttachments, } = {}) {\n let datasetId_;\n if (datasetId !== undefined && datasetName !== undefined) {\n throw new Error(\"Must provide either datasetName or datasetId, not both\");\n }\n else if (datasetId !== undefined) {\n datasetId_ = datasetId;\n }\n else if (datasetName !== undefined) {\n const dataset = await this.readDataset({ datasetName });\n datasetId_ = dataset.id;\n }\n else {\n throw new Error(\"Must provide a datasetName or datasetId\");\n }\n const params = new URLSearchParams({ dataset: datasetId_ });\n const dataset_version = asOf\n ? typeof asOf === \"string\"\n ? asOf\n : asOf?.toISOString()\n : undefined;\n if (dataset_version) {\n params.append(\"as_of\", dataset_version);\n }\n const inlineS3Urls_ = inlineS3Urls ?? true;\n params.append(\"inline_s3_urls\", inlineS3Urls_.toString());\n if (exampleIds !== undefined) {\n for (const id_ of exampleIds) {\n params.append(\"id\", id_);\n }\n }\n if (splits !== undefined) {\n for (const split of splits) {\n params.append(\"splits\", split);\n }\n }\n if (metadata !== undefined) {\n const serializedMetadata = JSON.stringify(metadata);\n params.append(\"metadata\", serializedMetadata);\n }\n if (limit !== undefined) {\n params.append(\"limit\", limit.toString());\n }\n if (offset !== undefined) {\n params.append(\"offset\", offset.toString());\n }\n if (filter !== undefined) {\n params.append(\"filter\", filter);\n }\n if (includeAttachments === true) {\n [\"attachment_urls\", \"outputs\", \"metadata\"].forEach((field) => params.append(\"select\", field));\n }\n let i = 0;\n for await (const rawExamples of this._getPaginated(\"/examples\", params)) {\n for (const rawExample of rawExamples) {\n const { attachment_urls, ...rest } = rawExample;\n const example = rest;\n if (attachment_urls) {\n example.attachments = Object.entries(attachment_urls).reduce((acc, [key, value]) => {\n acc[key.slice(\"attachment.\".length)] = {\n presigned_url: value.presigned_url,\n mime_type: value.mime_type || undefined,\n };\n return acc;\n }, {});\n }\n yield example;\n i++;\n }\n if (limit !== undefined && i >= limit) {\n break;\n }\n }\n }\n async deleteExample(exampleId) {\n (0, _uuid_js_1.assertUuid)(exampleId);\n const path = `/examples/${exampleId}`;\n await this.caller.call(async () => {\n const res = await this._fetch(this.apiUrl + path, {\n method: \"DELETE\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, `delete ${path}`, true);\n return res;\n });\n }\n /**\n * Delete multiple examples by ID.\n * @param exampleIds - The IDs of the examples to delete\n * @param options - Optional settings for deletion\n * @param options.hardDelete - If true, permanently delete examples. If false (default), soft delete them.\n */\n async deleteExamples(exampleIds, options) {\n // Validate all UUIDs\n exampleIds.forEach((id) => (0, _uuid_js_1.assertUuid)(id));\n if (options?.hardDelete) {\n // Hard delete uses POST to a different platform endpoint\n const path = this._getPlatformEndpointPath(\"datasets/examples/delete\");\n await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}${path}`, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n example_ids: exampleIds,\n hard_delete: true,\n }),\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"hard delete examples\", true);\n return res;\n });\n }\n else {\n // Soft delete uses DELETE with query params\n const params = new URLSearchParams();\n exampleIds.forEach((id) => params.append(\"example_ids\", id));\n await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/examples?${params.toString()}`, {\n method: \"DELETE\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"delete examples\", true);\n return res;\n });\n }\n }\n async updateExample(exampleIdOrUpdate, update) {\n let exampleId;\n if (update) {\n exampleId = exampleIdOrUpdate;\n }\n else {\n exampleId = exampleIdOrUpdate.id;\n }\n (0, _uuid_js_1.assertUuid)(exampleId);\n let updateToUse;\n if (update) {\n updateToUse = { id: exampleId, ...update };\n }\n else {\n updateToUse = exampleIdOrUpdate;\n }\n let datasetId;\n if (updateToUse.dataset_id !== undefined) {\n datasetId = updateToUse.dataset_id;\n }\n else {\n const example = await this.readExample(exampleId);\n datasetId = example.dataset_id;\n }\n return this._updateExamplesMultipart(datasetId, [updateToUse]);\n }\n async updateExamples(update) {\n // We will naively get dataset id from first example and assume it works for all\n let datasetId;\n if (update[0].dataset_id === undefined) {\n const example = await this.readExample(update[0].id);\n datasetId = example.dataset_id;\n }\n else {\n datasetId = update[0].dataset_id;\n }\n return this._updateExamplesMultipart(datasetId, update);\n }\n /**\n * Get dataset version by closest date or exact tag.\n *\n * Use this to resolve the nearest version to a given timestamp or for a given tag.\n *\n * @param options The options for getting the dataset version\n * @param options.datasetId The ID of the dataset\n * @param options.datasetName The name of the dataset\n * @param options.asOf The timestamp of the dataset to retrieve\n * @param options.tag The tag of the dataset to retrieve\n * @returns The dataset version\n */\n async readDatasetVersion({ datasetId, datasetName, asOf, tag, }) {\n let resolvedDatasetId;\n if (!datasetId) {\n const dataset = await this.readDataset({ datasetName });\n resolvedDatasetId = dataset.id;\n }\n else {\n resolvedDatasetId = datasetId;\n }\n (0, _uuid_js_1.assertUuid)(resolvedDatasetId);\n if ((asOf && tag) || (!asOf && !tag)) {\n throw new Error(\"Exactly one of asOf and tag must be specified.\");\n }\n const params = new URLSearchParams();\n if (asOf !== undefined) {\n params.append(\"as_of\", typeof asOf === \"string\" ? asOf : asOf.toISOString());\n }\n if (tag !== undefined) {\n params.append(\"tag\", tag);\n }\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/datasets/${resolvedDatasetId}/version?${params.toString()}`, {\n method: \"GET\",\n headers: { ...this.headers },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"read dataset version\");\n return res;\n });\n return await response.json();\n }\n async listDatasetSplits({ datasetId, datasetName, asOf, }) {\n let datasetId_;\n if (datasetId === undefined && datasetName === undefined) {\n throw new Error(\"Must provide dataset name or ID\");\n }\n else if (datasetId !== undefined && datasetName !== undefined) {\n throw new Error(\"Must provide either datasetName or datasetId, not both\");\n }\n else if (datasetId === undefined) {\n const dataset = await this.readDataset({ datasetName });\n datasetId_ = dataset.id;\n }\n else {\n datasetId_ = datasetId;\n }\n (0, _uuid_js_1.assertUuid)(datasetId_);\n const params = new URLSearchParams();\n const dataset_version = asOf\n ? typeof asOf === \"string\"\n ? asOf\n : asOf?.toISOString()\n : undefined;\n if (dataset_version) {\n params.append(\"as_of\", dataset_version);\n }\n const response = await this._get(`/datasets/${datasetId_}/splits`, params);\n return response;\n }\n async updateDatasetSplits({ datasetId, datasetName, splitName, exampleIds, remove = false, }) {\n let datasetId_;\n if (datasetId === undefined && datasetName === undefined) {\n throw new Error(\"Must provide dataset name or ID\");\n }\n else if (datasetId !== undefined && datasetName !== undefined) {\n throw new Error(\"Must provide either datasetName or datasetId, not both\");\n }\n else if (datasetId === undefined) {\n const dataset = await this.readDataset({ datasetName });\n datasetId_ = dataset.id;\n }\n else {\n datasetId_ = datasetId;\n }\n (0, _uuid_js_1.assertUuid)(datasetId_);\n const data = {\n split_name: splitName,\n examples: exampleIds.map((id) => {\n (0, _uuid_js_1.assertUuid)(id);\n return id;\n }),\n remove,\n };\n const body = JSON.stringify(data);\n await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/datasets/${datasetId_}/splits`, {\n method: \"PUT\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"update dataset splits\", true);\n return res;\n });\n }\n /**\n * @deprecated This method is deprecated and will be removed in future LangSmith versions, use `evaluate` from `langsmith/evaluation` instead.\n */\n async evaluateRun(run, evaluator, { sourceInfo, loadChildRuns, referenceExample, } = { loadChildRuns: false }) {\n (0, warn_js_1.warnOnce)(\"This method is deprecated and will be removed in future LangSmith versions, use `evaluate` from `langsmith/evaluation` instead.\");\n let run_;\n if (typeof run === \"string\") {\n run_ = await this.readRun(run, { loadChildRuns });\n }\n else if (typeof run === \"object\" && \"id\" in run) {\n run_ = run;\n }\n else {\n throw new Error(`Invalid run type: ${typeof run}`);\n }\n if (run_.reference_example_id !== null &&\n run_.reference_example_id !== undefined) {\n referenceExample = await this.readExample(run_.reference_example_id);\n }\n const feedbackResult = await evaluator.evaluateRun(run_, referenceExample);\n const [_, feedbacks] = await this._logEvaluationFeedback(feedbackResult, run_, sourceInfo);\n return feedbacks[0];\n }\n async createFeedback(runId, key, { score, value, correction, comment, sourceInfo, feedbackSourceType = \"api\", sourceRunId, feedbackId, feedbackConfig, projectId, comparativeExperimentId, }) {\n if (!runId && !projectId) {\n throw new Error(\"One of runId or projectId must be provided\");\n }\n if (runId && projectId) {\n throw new Error(\"Only one of runId or projectId can be provided\");\n }\n const feedback_source = {\n type: feedbackSourceType ?? \"api\",\n metadata: sourceInfo ?? {},\n };\n if (sourceRunId !== undefined &&\n feedback_source?.metadata !== undefined &&\n !feedback_source.metadata[\"__run\"]) {\n feedback_source.metadata[\"__run\"] = { run_id: sourceRunId };\n }\n if (feedback_source?.metadata !== undefined &&\n feedback_source.metadata[\"__run\"]?.run_id !== undefined) {\n (0, _uuid_js_1.assertUuid)(feedback_source.metadata[\"__run\"].run_id);\n }\n const feedback = {\n id: feedbackId ?? uuid.v4(),\n run_id: runId,\n key,\n score: _formatFeedbackScore(score),\n value,\n correction,\n comment,\n feedback_source: feedback_source,\n comparative_experiment_id: comparativeExperimentId,\n feedbackConfig,\n session_id: projectId,\n };\n const body = JSON.stringify(feedback);\n const url = `${this.apiUrl}/feedback`;\n await this.caller.call(async () => {\n const res = await this._fetch(url, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"create feedback\", true);\n return res;\n });\n return feedback;\n }\n async updateFeedback(feedbackId, { score, value, correction, comment, }) {\n const feedbackUpdate = {};\n if (score !== undefined && score !== null) {\n feedbackUpdate[\"score\"] = _formatFeedbackScore(score);\n }\n if (value !== undefined && value !== null) {\n feedbackUpdate[\"value\"] = value;\n }\n if (correction !== undefined && correction !== null) {\n feedbackUpdate[\"correction\"] = correction;\n }\n if (comment !== undefined && comment !== null) {\n feedbackUpdate[\"comment\"] = comment;\n }\n (0, _uuid_js_1.assertUuid)(feedbackId);\n const body = JSON.stringify(feedbackUpdate);\n await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/feedback/${feedbackId}`, {\n method: \"PATCH\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"update feedback\", true);\n return res;\n });\n }\n async readFeedback(feedbackId) {\n (0, _uuid_js_1.assertUuid)(feedbackId);\n const path = `/feedback/${feedbackId}`;\n const response = await this._get(path);\n return response;\n }\n async deleteFeedback(feedbackId) {\n (0, _uuid_js_1.assertUuid)(feedbackId);\n const path = `/feedback/${feedbackId}`;\n await this.caller.call(async () => {\n const res = await this._fetch(this.apiUrl + path, {\n method: \"DELETE\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, `delete ${path}`, true);\n return res;\n });\n }\n async *listFeedback({ runIds, feedbackKeys, feedbackSourceTypes, } = {}) {\n const queryParams = new URLSearchParams();\n if (runIds) {\n for (const runId of runIds) {\n (0, _uuid_js_1.assertUuid)(runId);\n queryParams.append(\"run\", runId);\n }\n }\n if (feedbackKeys) {\n for (const key of feedbackKeys) {\n queryParams.append(\"key\", key);\n }\n }\n if (feedbackSourceTypes) {\n for (const type of feedbackSourceTypes) {\n queryParams.append(\"source\", type);\n }\n }\n for await (const feedbacks of this._getPaginated(\"/feedback\", queryParams)) {\n yield* feedbacks;\n }\n }\n /**\n * Creates a presigned feedback token and URL.\n *\n * The token can be used to authorize feedback metrics without\n * needing an API key. This is useful for giving browser-based\n * applications the ability to submit feedback without needing\n * to expose an API key.\n *\n * @param runId The ID of the run.\n * @param feedbackKey The feedback key.\n * @param options Additional options for the token.\n * @param options.expiration The expiration time for the token.\n *\n * @returns A promise that resolves to a FeedbackIngestToken.\n */\n async createPresignedFeedbackToken(runId, feedbackKey, { expiration, feedbackConfig, } = {}) {\n const body = {\n run_id: runId,\n feedback_key: feedbackKey,\n feedback_config: feedbackConfig,\n };\n if (expiration) {\n if (typeof expiration === \"string\") {\n body[\"expires_at\"] = expiration;\n }\n else if (expiration?.hours || expiration?.minutes || expiration?.days) {\n body[\"expires_in\"] = expiration;\n }\n }\n else {\n body[\"expires_in\"] = {\n hours: 3,\n };\n }\n const serializedBody = JSON.stringify(body);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/feedback/tokens`, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body: serializedBody,\n });\n await (0, error_js_1.raiseForStatus)(res, \"create presigned feedback token\");\n return res;\n });\n return await response.json();\n }\n async createComparativeExperiment({ name, experimentIds, referenceDatasetId, createdAt, description, metadata, id, }) {\n if (experimentIds.length === 0) {\n throw new Error(\"At least one experiment is required\");\n }\n if (!referenceDatasetId) {\n referenceDatasetId = (await this.readProject({\n projectId: experimentIds[0],\n })).reference_dataset_id;\n }\n if (!referenceDatasetId == null) {\n throw new Error(\"A reference dataset is required\");\n }\n const body = {\n id,\n name,\n experiment_ids: experimentIds,\n reference_dataset_id: referenceDatasetId,\n description,\n created_at: (createdAt ?? new Date())?.toISOString(),\n extra: {},\n };\n if (metadata)\n body.extra[\"metadata\"] = metadata;\n const serializedBody = JSON.stringify(body);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/datasets/comparative`, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body: serializedBody,\n });\n await (0, error_js_1.raiseForStatus)(res, \"create comparative experiment\");\n return res;\n });\n return response.json();\n }\n /**\n * Retrieves a list of presigned feedback tokens for a given run ID.\n * @param runId The ID of the run.\n * @returns An async iterable of FeedbackIngestToken objects.\n */\n async *listPresignedFeedbackTokens(runId) {\n (0, _uuid_js_1.assertUuid)(runId);\n const params = new URLSearchParams({ run_id: runId });\n for await (const tokens of this._getPaginated(\"/feedback/tokens\", params)) {\n yield* tokens;\n }\n }\n _selectEvalResults(results) {\n let results_;\n if (\"results\" in results) {\n results_ = results.results;\n }\n else if (Array.isArray(results)) {\n results_ = results;\n }\n else {\n results_ = [results];\n }\n return results_;\n }\n async _logEvaluationFeedback(evaluatorResponse, run, sourceInfo) {\n const evalResults = this._selectEvalResults(evaluatorResponse);\n const feedbacks = [];\n for (const res of evalResults) {\n let sourceInfo_ = sourceInfo || {};\n if (res.evaluatorInfo) {\n sourceInfo_ = { ...res.evaluatorInfo, ...sourceInfo_ };\n }\n let runId_ = null;\n if (res.targetRunId) {\n runId_ = res.targetRunId;\n }\n else if (run) {\n runId_ = run.id;\n }\n feedbacks.push(await this.createFeedback(runId_, res.key, {\n score: res.score,\n value: res.value,\n comment: res.comment,\n correction: res.correction,\n sourceInfo: sourceInfo_,\n sourceRunId: res.sourceRunId,\n feedbackConfig: res.feedbackConfig,\n feedbackSourceType: \"model\",\n }));\n }\n return [evalResults, feedbacks];\n }\n async logEvaluationFeedback(evaluatorResponse, run, sourceInfo) {\n const [results] = await this._logEvaluationFeedback(evaluatorResponse, run, sourceInfo);\n return results;\n }\n /**\n * API for managing annotation queues\n */\n /**\n * List the annotation queues on the LangSmith API.\n * @param options - The options for listing annotation queues\n * @param options.queueIds - The IDs of the queues to filter by\n * @param options.name - The name of the queue to filter by\n * @param options.nameContains - The substring that the queue name should contain\n * @param options.limit - The maximum number of queues to return\n * @returns An iterator of AnnotationQueue objects\n */\n async *listAnnotationQueues(options = {}) {\n const { queueIds, name, nameContains, limit } = options;\n const params = new URLSearchParams();\n if (queueIds) {\n queueIds.forEach((id, i) => {\n (0, _uuid_js_1.assertUuid)(id, `queueIds[${i}]`);\n params.append(\"ids\", id);\n });\n }\n if (name)\n params.append(\"name\", name);\n if (nameContains)\n params.append(\"name_contains\", nameContains);\n params.append(\"limit\", (limit !== undefined ? Math.min(limit, 100) : 100).toString());\n let count = 0;\n for await (const queues of this._getPaginated(\"/annotation-queues\", params)) {\n yield* queues;\n count++;\n if (limit !== undefined && count >= limit)\n break;\n }\n }\n /**\n * Create an annotation queue on the LangSmith API.\n * @param options - The options for creating an annotation queue\n * @param options.name - The name of the annotation queue\n * @param options.description - The description of the annotation queue\n * @param options.queueId - The ID of the annotation queue\n * @returns The created AnnotationQueue object\n */\n async createAnnotationQueue(options) {\n const { name, description, queueId, rubricInstructions } = options;\n const body = {\n name,\n description,\n id: queueId || uuid.v4(),\n rubric_instructions: rubricInstructions,\n };\n const serializedBody = JSON.stringify(Object.fromEntries(Object.entries(body).filter(([_, v]) => v !== undefined)));\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/annotation-queues`, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body: serializedBody,\n });\n await (0, error_js_1.raiseForStatus)(res, \"create annotation queue\");\n return res;\n });\n return response.json();\n }\n /**\n * Read an annotation queue with the specified queue ID.\n * @param queueId - The ID of the annotation queue to read\n * @returns The AnnotationQueueWithDetails object\n */\n async readAnnotationQueue(queueId) {\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/annotation-queues/${(0, _uuid_js_1.assertUuid)(queueId, \"queueId\")}`, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"read annotation queue\");\n return res;\n });\n return response.json();\n }\n /**\n * Update an annotation queue with the specified queue ID.\n * @param queueId - The ID of the annotation queue to update\n * @param options - The options for updating the annotation queue\n * @param options.name - The new name for the annotation queue\n * @param options.description - The new description for the annotation queue\n */\n async updateAnnotationQueue(queueId, options) {\n const { name, description, rubricInstructions } = options;\n const body = JSON.stringify({\n name,\n description,\n rubric_instructions: rubricInstructions,\n });\n await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/annotation-queues/${(0, _uuid_js_1.assertUuid)(queueId, \"queueId\")}`, {\n method: \"PATCH\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"update annotation queue\", true);\n return res;\n });\n }\n /**\n * Delete an annotation queue with the specified queue ID.\n * @param queueId - The ID of the annotation queue to delete\n */\n async deleteAnnotationQueue(queueId) {\n await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/annotation-queues/${(0, _uuid_js_1.assertUuid)(queueId, \"queueId\")}`, {\n method: \"DELETE\",\n headers: { ...this.headers, Accept: \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"delete annotation queue\", true);\n return res;\n });\n }\n /**\n * Add runs to an annotation queue with the specified queue ID.\n * @param queueId - The ID of the annotation queue\n * @param runIds - The IDs of the runs to be added to the annotation queue\n */\n async addRunsToAnnotationQueue(queueId, runIds) {\n const body = JSON.stringify(runIds.map((id, i) => (0, _uuid_js_1.assertUuid)(id, `runIds[${i}]`).toString()));\n await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/annotation-queues/${(0, _uuid_js_1.assertUuid)(queueId, \"queueId\")}/runs`, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"add runs to annotation queue\", true);\n return res;\n });\n }\n /**\n * Get a run from an annotation queue at the specified index.\n * @param queueId - The ID of the annotation queue\n * @param index - The index of the run to retrieve\n * @returns A Promise that resolves to a RunWithAnnotationQueueInfo object\n * @throws {Error} If the run is not found at the given index or for other API-related errors\n */\n async getRunFromAnnotationQueue(queueId, index) {\n const baseUrl = `/annotation-queues/${(0, _uuid_js_1.assertUuid)(queueId, \"queueId\")}/run`;\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}${baseUrl}/${index}`, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"get run from annotation queue\");\n return res;\n });\n return response.json();\n }\n /**\n * Delete a run from an an annotation queue.\n * @param queueId - The ID of the annotation queue to delete the run from\n * @param queueRunId - The ID of the run to delete from the annotation queue\n */\n async deleteRunFromAnnotationQueue(queueId, queueRunId) {\n await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/annotation-queues/${(0, _uuid_js_1.assertUuid)(queueId, \"queueId\")}/runs/${(0, _uuid_js_1.assertUuid)(queueRunId, \"queueRunId\")}`, {\n method: \"DELETE\",\n headers: { ...this.headers, Accept: \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"delete run from annotation queue\", true);\n return res;\n });\n }\n /**\n * Get the size of an annotation queue.\n * @param queueId - The ID of the annotation queue\n */\n async getSizeFromAnnotationQueue(queueId) {\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/annotation-queues/${(0, _uuid_js_1.assertUuid)(queueId, \"queueId\")}/size`, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"get size from annotation queue\");\n return res;\n });\n return response.json();\n }\n async _currentTenantIsOwner(owner) {\n const settings = await this._getSettings();\n return owner == \"-\" || settings.tenant_handle === owner;\n }\n async _ownerConflictError(action, owner) {\n const settings = await this._getSettings();\n return new Error(`Cannot ${action} for another tenant.\\n\n Current tenant: ${settings.tenant_handle}\\n\n Requested tenant: ${owner}`);\n }\n async _getLatestCommitHash(promptOwnerAndName) {\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/commits/${promptOwnerAndName}/?limit=${1}&offset=${0}`, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"get latest commit hash\");\n return res;\n });\n const json = await response.json();\n if (json.commits.length === 0) {\n return undefined;\n }\n return json.commits[0].commit_hash;\n }\n async _likeOrUnlikePrompt(promptIdentifier, like) {\n const [owner, promptName, _] = (0, prompts_js_1.parsePromptIdentifier)(promptIdentifier);\n const body = JSON.stringify({ like: like });\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/likes/${owner}/${promptName}`, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, `${like ? \"like\" : \"unlike\"} prompt`);\n return res;\n });\n return response.json();\n }\n async _getPromptUrl(promptIdentifier) {\n const [owner, promptName, commitHash] = (0, prompts_js_1.parsePromptIdentifier)(promptIdentifier);\n if (!(await this._currentTenantIsOwner(owner))) {\n if (commitHash !== \"latest\") {\n return `${this.getHostUrl()}/hub/${owner}/${promptName}/${commitHash.substring(0, 8)}`;\n }\n else {\n return `${this.getHostUrl()}/hub/${owner}/${promptName}`;\n }\n }\n else {\n const settings = await this._getSettings();\n if (commitHash !== \"latest\") {\n return `${this.getHostUrl()}/prompts/${promptName}/${commitHash.substring(0, 8)}?organizationId=${settings.id}`;\n }\n else {\n return `${this.getHostUrl()}/prompts/${promptName}?organizationId=${settings.id}`;\n }\n }\n }\n async promptExists(promptIdentifier) {\n const prompt = await this.getPrompt(promptIdentifier);\n return !!prompt;\n }\n async likePrompt(promptIdentifier) {\n return this._likeOrUnlikePrompt(promptIdentifier, true);\n }\n async unlikePrompt(promptIdentifier) {\n return this._likeOrUnlikePrompt(promptIdentifier, false);\n }\n async *listCommits(promptOwnerAndName) {\n for await (const commits of this._getPaginated(`/commits/${promptOwnerAndName}/`, new URLSearchParams(), (res) => res.commits)) {\n yield* commits;\n }\n }\n async *listPrompts(options) {\n const params = new URLSearchParams();\n params.append(\"sort_field\", options?.sortField ?? \"updated_at\");\n params.append(\"sort_direction\", \"desc\");\n params.append(\"is_archived\", (!!options?.isArchived).toString());\n if (options?.isPublic !== undefined) {\n params.append(\"is_public\", options.isPublic.toString());\n }\n if (options?.query) {\n params.append(\"query\", options.query);\n }\n for await (const prompts of this._getPaginated(\"/repos\", params, (res) => res.repos)) {\n yield* prompts;\n }\n }\n async getPrompt(promptIdentifier) {\n const [owner, promptName, _] = (0, prompts_js_1.parsePromptIdentifier)(promptIdentifier);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/repos/${owner}/${promptName}`, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n if (res?.status === 404) {\n return null;\n }\n await (0, error_js_1.raiseForStatus)(res, \"get prompt\");\n return res;\n });\n const result = await response?.json();\n if (result?.repo) {\n return result.repo;\n }\n else {\n return null;\n }\n }\n async createPrompt(promptIdentifier, options) {\n const settings = await this._getSettings();\n if (options?.isPublic && !settings.tenant_handle) {\n throw new Error(`Cannot create a public prompt without first\\n\n creating a LangChain Hub handle.\n You can add a handle by creating a public prompt at:\\n\n https://smith.langchain.com/prompts`);\n }\n const [owner, promptName, _] = (0, prompts_js_1.parsePromptIdentifier)(promptIdentifier);\n if (!(await this._currentTenantIsOwner(owner))) {\n throw await this._ownerConflictError(\"create a prompt\", owner);\n }\n const data = {\n repo_handle: promptName,\n ...(options?.description && { description: options.description }),\n ...(options?.readme && { readme: options.readme }),\n ...(options?.tags && { tags: options.tags }),\n is_public: !!options?.isPublic,\n };\n const body = JSON.stringify(data);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/repos/`, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"create prompt\");\n return res;\n });\n const { repo } = await response.json();\n return repo;\n }\n async createCommit(promptIdentifier, object, options) {\n if (!(await this.promptExists(promptIdentifier))) {\n throw new Error(\"Prompt does not exist, you must create it first.\");\n }\n const [owner, promptName, _] = (0, prompts_js_1.parsePromptIdentifier)(promptIdentifier);\n const resolvedParentCommitHash = options?.parentCommitHash === \"latest\" || !options?.parentCommitHash\n ? await this._getLatestCommitHash(`${owner}/${promptName}`)\n : options?.parentCommitHash;\n const payload = {\n manifest: JSON.parse(JSON.stringify(object)),\n parent_commit: resolvedParentCommitHash,\n };\n const body = JSON.stringify(payload);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/commits/${owner}/${promptName}`, {\n method: \"POST\",\n headers: { ...this.headers, \"Content-Type\": \"application/json\" },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"create commit\");\n return res;\n });\n const result = await response.json();\n return this._getPromptUrl(`${owner}/${promptName}${result.commit_hash ? `:${result.commit_hash}` : \"\"}`);\n }\n /**\n * Update examples with attachments using multipart form data.\n * @param updates List of ExampleUpdateWithAttachments objects to upsert\n * @returns Promise with the update response\n */\n async updateExamplesMultipart(datasetId, updates = []) {\n return this._updateExamplesMultipart(datasetId, updates);\n }\n async _updateExamplesMultipart(datasetId, updates = []) {\n if (!(await this._getDatasetExamplesMultiPartSupport())) {\n throw new Error(\"Your LangSmith deployment does not allow using the multipart examples endpoint, please upgrade your deployment to the latest version.\");\n }\n const formData = new FormData();\n for (const example of updates) {\n const exampleId = example.id;\n // Prepare the main example body\n const exampleBody = {\n ...(example.metadata && { metadata: example.metadata }),\n ...(example.split && { split: example.split }),\n };\n // Add main example data\n const stringifiedExample = (0, index_js_2.serialize)(exampleBody, `Serializing body for example with id: ${exampleId}`);\n const exampleBlob = new Blob([stringifiedExample], {\n type: \"application/json\",\n });\n formData.append(exampleId, exampleBlob);\n // Add inputs if present\n if (example.inputs) {\n const stringifiedInputs = (0, index_js_2.serialize)(example.inputs, `Serializing inputs for example with id: ${exampleId}`);\n const inputsBlob = new Blob([stringifiedInputs], {\n type: \"application/json\",\n });\n formData.append(`${exampleId}.inputs`, inputsBlob);\n }\n // Add outputs if present\n if (example.outputs) {\n const stringifiedOutputs = (0, index_js_2.serialize)(example.outputs, `Serializing outputs whle updating example with id: ${exampleId}`);\n const outputsBlob = new Blob([stringifiedOutputs], {\n type: \"application/json\",\n });\n formData.append(`${exampleId}.outputs`, outputsBlob);\n }\n // Add attachments if present\n if (example.attachments) {\n for (const [name, attachment] of Object.entries(example.attachments)) {\n let mimeType;\n let data;\n if (Array.isArray(attachment)) {\n [mimeType, data] = attachment;\n }\n else {\n mimeType = attachment.mimeType;\n data = attachment.data;\n }\n const attachmentBlob = new Blob([data], {\n type: `${mimeType}; length=${data.byteLength}`,\n });\n formData.append(`${exampleId}.attachment.${name}`, attachmentBlob);\n }\n }\n if (example.attachments_operations) {\n const stringifiedAttachmentsOperations = (0, index_js_2.serialize)(example.attachments_operations, `Serializing attachments while updating example with id: ${exampleId}`);\n const attachmentsOperationsBlob = new Blob([stringifiedAttachmentsOperations], {\n type: \"application/json\",\n });\n formData.append(`${exampleId}.attachments_operations`, attachmentsOperationsBlob);\n }\n }\n const datasetIdToUse = datasetId ?? updates[0]?.dataset_id;\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}${this._getPlatformEndpointPath(`datasets/${datasetIdToUse}/examples`)}`, {\n method: \"PATCH\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body: formData,\n });\n await (0, error_js_1.raiseForStatus)(res, \"update examples\");\n return res;\n });\n return response.json();\n }\n /**\n * Upload examples with attachments using multipart form data.\n * @param uploads List of ExampleUploadWithAttachments objects to upload\n * @returns Promise with the upload response\n * @deprecated This method is deprecated and will be removed in future LangSmith versions, please use `createExamples` instead\n */\n async uploadExamplesMultipart(datasetId, uploads = []) {\n return this._uploadExamplesMultipart(datasetId, uploads);\n }\n async _uploadExamplesMultipart(datasetId, uploads = []) {\n if (!(await this._getDatasetExamplesMultiPartSupport())) {\n throw new Error(\"Your LangSmith deployment does not allow using the multipart examples endpoint, please upgrade your deployment to the latest version.\");\n }\n const formData = new FormData();\n for (const example of uploads) {\n const exampleId = (example.id ?? uuid.v4()).toString();\n // Prepare the main example body\n const exampleBody = {\n created_at: example.created_at,\n ...(example.metadata && { metadata: example.metadata }),\n ...(example.split && { split: example.split }),\n ...(example.source_run_id && { source_run_id: example.source_run_id }),\n ...(example.use_source_run_io && {\n use_source_run_io: example.use_source_run_io,\n }),\n ...(example.use_source_run_attachments && {\n use_source_run_attachments: example.use_source_run_attachments,\n }),\n };\n // Add main example data\n const stringifiedExample = (0, index_js_2.serialize)(exampleBody, `Serializing body for uploaded example with id: ${exampleId}`);\n const exampleBlob = new Blob([stringifiedExample], {\n type: \"application/json\",\n });\n formData.append(exampleId, exampleBlob);\n // Add inputs if present\n if (example.inputs) {\n const stringifiedInputs = (0, index_js_2.serialize)(example.inputs, `Serializing inputs for uploaded example with id: ${exampleId}`);\n const inputsBlob = new Blob([stringifiedInputs], {\n type: \"application/json\",\n });\n formData.append(`${exampleId}.inputs`, inputsBlob);\n }\n // Add outputs if present\n if (example.outputs) {\n const stringifiedOutputs = (0, index_js_2.serialize)(example.outputs, `Serializing outputs for uploaded example with id: ${exampleId}`);\n const outputsBlob = new Blob([stringifiedOutputs], {\n type: \"application/json\",\n });\n formData.append(`${exampleId}.outputs`, outputsBlob);\n }\n // Add attachments if present\n if (example.attachments) {\n for (const [name, attachment] of Object.entries(example.attachments)) {\n let mimeType;\n let data;\n if (Array.isArray(attachment)) {\n [mimeType, data] = attachment;\n }\n else {\n mimeType = attachment.mimeType;\n data = attachment.data;\n }\n const attachmentBlob = new Blob([data], {\n type: `${mimeType}; length=${data.byteLength}`,\n });\n formData.append(`${exampleId}.attachment.${name}`, attachmentBlob);\n }\n }\n }\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}${this._getPlatformEndpointPath(`datasets/${datasetId}/examples`)}`, {\n method: \"POST\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body: formData,\n });\n await (0, error_js_1.raiseForStatus)(res, \"upload examples\");\n return res;\n });\n return response.json();\n }\n async updatePrompt(promptIdentifier, options) {\n if (!(await this.promptExists(promptIdentifier))) {\n throw new Error(\"Prompt does not exist, you must create it first.\");\n }\n const [owner, promptName] = (0, prompts_js_1.parsePromptIdentifier)(promptIdentifier);\n if (!(await this._currentTenantIsOwner(owner))) {\n throw await this._ownerConflictError(\"update a prompt\", owner);\n }\n const payload = {};\n if (options?.description !== undefined)\n payload.description = options.description;\n if (options?.readme !== undefined)\n payload.readme = options.readme;\n if (options?.tags !== undefined)\n payload.tags = options.tags;\n if (options?.isPublic !== undefined)\n payload.is_public = options.isPublic;\n if (options?.isArchived !== undefined)\n payload.is_archived = options.isArchived;\n // Check if payload is empty\n if (Object.keys(payload).length === 0) {\n throw new Error(\"No valid update options provided\");\n }\n const body = JSON.stringify(payload);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/repos/${owner}/${promptName}`, {\n method: \"PATCH\",\n headers: {\n ...this.headers,\n \"Content-Type\": \"application/json\",\n },\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n body,\n });\n await (0, error_js_1.raiseForStatus)(res, \"update prompt\");\n return res;\n });\n return response.json();\n }\n async deletePrompt(promptIdentifier) {\n if (!(await this.promptExists(promptIdentifier))) {\n throw new Error(\"Prompt does not exist, you must create it first.\");\n }\n const [owner, promptName, _] = (0, prompts_js_1.parsePromptIdentifier)(promptIdentifier);\n if (!(await this._currentTenantIsOwner(owner))) {\n throw await this._ownerConflictError(\"delete a prompt\", owner);\n }\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/repos/${owner}/${promptName}`, {\n method: \"DELETE\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"delete prompt\");\n return res;\n });\n return response.json();\n }\n async pullPromptCommit(promptIdentifier, options) {\n const [owner, promptName, commitHash] = (0, prompts_js_1.parsePromptIdentifier)(promptIdentifier);\n const response = await this.caller.call(async () => {\n const res = await this._fetch(`${this.apiUrl}/commits/${owner}/${promptName}/${commitHash}${options?.includeModel ? \"?include_model=true\" : \"\"}`, {\n method: \"GET\",\n headers: this.headers,\n signal: AbortSignal.timeout(this.timeout_ms),\n ...this.fetchOptions,\n });\n await (0, error_js_1.raiseForStatus)(res, \"pull prompt commit\");\n return res;\n });\n const result = await response.json();\n return {\n owner,\n repo: promptName,\n commit_hash: result.commit_hash,\n manifest: result.manifest,\n examples: result.examples,\n };\n }\n /**\n * This method should not be used directly, use `import { pull } from \"langchain/hub\"` instead.\n * Using this method directly returns the JSON string of the prompt rather than a LangChain object.\n * @private\n */\n async _pullPrompt(promptIdentifier, options) {\n const promptObject = await this.pullPromptCommit(promptIdentifier, {\n includeModel: options?.includeModel,\n });\n const prompt = JSON.stringify(promptObject.manifest);\n return prompt;\n }\n async pushPrompt(promptIdentifier, options) {\n // Create or update prompt metadata\n if (await this.promptExists(promptIdentifier)) {\n if (options && Object.keys(options).some((key) => key !== \"object\")) {\n await this.updatePrompt(promptIdentifier, {\n description: options?.description,\n readme: options?.readme,\n tags: options?.tags,\n isPublic: options?.isPublic,\n });\n }\n }\n else {\n await this.createPrompt(promptIdentifier, {\n description: options?.description,\n readme: options?.readme,\n tags: options?.tags,\n isPublic: options?.isPublic,\n });\n }\n if (!options?.object) {\n return await this._getPromptUrl(promptIdentifier);\n }\n // Create a commit with the new manifest\n const url = await this.createCommit(promptIdentifier, options?.object, {\n parentCommitHash: options?.parentCommitHash,\n });\n return url;\n }\n /**\n * Clone a public dataset to your own langsmith tenant.\n * This operation is idempotent. If you already have a dataset with the given name,\n * this function will do nothing.\n \n * @param {string} tokenOrUrl The token of the public dataset to clone.\n * @param {Object} [options] Additional options for cloning the dataset.\n * @param {string} [options.sourceApiUrl] The URL of the langsmith server where the data is hosted. Defaults to the API URL of your current client.\n * @param {string} [options.datasetName] The name of the dataset to create in your tenant. Defaults to the name of the public dataset.\n * @returns {Promise<void>}\n */\n async clonePublicDataset(tokenOrUrl, options = {}) {\n const { sourceApiUrl = this.apiUrl, datasetName } = options;\n const [parsedApiUrl, tokenUuid] = this.parseTokenOrUrl(tokenOrUrl, sourceApiUrl);\n const sourceClient = new Client({\n apiUrl: parsedApiUrl,\n // Placeholder API key not needed anymore in most cases, but\n // some private deployments may have API key-based rate limiting\n // that would cause this to fail if we provide no value.\n apiKey: \"placeholder\",\n });\n const ds = await sourceClient.readSharedDataset(tokenUuid);\n const finalDatasetName = datasetName || ds.name;\n try {\n if (await this.hasDataset({ datasetId: finalDatasetName })) {\n console.log(`Dataset ${finalDatasetName} already exists in your tenant. Skipping.`);\n return;\n }\n }\n catch (_) {\n // `.hasDataset` will throw an error if the dataset does not exist.\n // no-op in that case\n }\n // Fetch examples first, then create the dataset\n const examples = await sourceClient.listSharedExamples(tokenUuid);\n const dataset = await this.createDataset(finalDatasetName, {\n description: ds.description,\n dataType: ds.data_type || \"kv\",\n inputsSchema: ds.inputs_schema_definition ?? undefined,\n outputsSchema: ds.outputs_schema_definition ?? undefined,\n });\n try {\n await this.createExamples({\n inputs: examples.map((e) => e.inputs),\n outputs: examples.flatMap((e) => (e.outputs ? [e.outputs] : [])),\n datasetId: dataset.id,\n });\n }\n catch (e) {\n console.error(`An error occurred while creating dataset ${finalDatasetName}. ` +\n \"You should delete it manually.\");\n throw e;\n }\n }\n parseTokenOrUrl(urlOrToken, apiUrl, numParts = 2, kind = \"dataset\") {\n // Try parsing as UUID\n try {\n (0, _uuid_js_1.assertUuid)(urlOrToken); // Will throw if it's not a UUID.\n return [apiUrl, urlOrToken];\n }\n catch (_) {\n // no-op if it's not a uuid\n }\n // Parse as URL\n try {\n const parsedUrl = new URL(urlOrToken);\n const pathParts = parsedUrl.pathname\n .split(\"/\")\n .filter((part) => part !== \"\");\n if (pathParts.length >= numParts) {\n const tokenUuid = pathParts[pathParts.length - numParts];\n return [apiUrl, tokenUuid];\n }\n else {\n throw new Error(`Invalid public ${kind} URL: ${urlOrToken}`);\n }\n }\n catch (error) {\n throw new Error(`Invalid public ${kind} URL or token: ${urlOrToken}`);\n }\n }\n /**\n * Awaits all pending trace batches. Useful for environments where\n * you need to be sure that all tracing requests finish before execution ends,\n * such as serverless environments.\n *\n * @example\n * ```\n * import { Client } from \"langsmith\";\n *\n * const client = new Client();\n *\n * try {\n * // Tracing happens here\n * ...\n * } finally {\n * await client.awaitPendingTraceBatches();\n * }\n * ```\n *\n * @returns A promise that resolves once all currently pending traces have sent.\n */\n async awaitPendingTraceBatches() {\n if (this.manualFlushMode) {\n console.warn(\"[WARNING]: When tracing in manual flush mode, you must call `await client.flush()` manually to submit trace batches.\");\n return Promise.resolve();\n }\n await Promise.all([\n ...this.autoBatchQueue.items.map(({ itemPromise }) => itemPromise),\n this.batchIngestCaller.queue.onIdle(),\n ]);\n if (this.langSmithToOTELTranslator !== undefined) {\n await (0, otel_js_1.getDefaultOTLPTracerComponents)()?.DEFAULT_LANGSMITH_SPAN_PROCESSOR?.forceFlush();\n }\n }\n}\nexports.Client = Client;\nfunction isExampleCreate(input) {\n return \"dataset_id\" in input || \"dataset_name\" in input;\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isTracingEnabled = void 0;\nconst env_js_1 = require(\"./utils/env.cjs\");\nconst isTracingEnabled = (tracingEnabled) => {\n if (tracingEnabled !== undefined) {\n return tracingEnabled;\n }\n const envVars = [\"TRACING_V2\", \"TRACING\"];\n return !!envVars.find((envVar) => (0, env_js_1.getLangSmithEnvironmentVariable)(envVar) === \"true\");\n};\nexports.isTracingEnabled = isTracingEnabled;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports._REPLICA_TRACE_ROOTS_KEY = exports._LC_CONTEXT_VARIABLES_KEY = void 0;\nexports._LC_CONTEXT_VARIABLES_KEY = Symbol.for(\"lc:context_variables\");\nexports._REPLICA_TRACE_ROOTS_KEY = Symbol.for(\"langsmith:replica_trace_roots\");\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getContextVar = getContextVar;\nexports.setContextVar = setContextVar;\nconst constants_js_1 = require(\"../singletons/constants.cjs\");\n/**\n * Get a context variable from a run tree instance\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getContextVar(runTree, key) {\n if (constants_js_1._LC_CONTEXT_VARIABLES_KEY in runTree) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const contextVars = runTree[constants_js_1._LC_CONTEXT_VARIABLES_KEY];\n return contextVars[key];\n }\n return undefined;\n}\n/**\n * Set a context variable on a run tree instance\n */\nfunction setContextVar(\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nrunTree, key, value) {\n const contextVars = constants_js_1._LC_CONTEXT_VARIABLES_KEY in runTree\n ? // eslint-disable-next-line @typescript-eslint/no-explicit-any\n runTree[constants_js_1._LC_CONTEXT_VARIABLES_KEY]\n : {};\n contextVars[key] = value;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n runTree[constants_js_1._LC_CONTEXT_VARIABLES_KEY] = contextVars;\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.RunTree = void 0;\nexports.convertToDottedOrderFormat = convertToDottedOrderFormat;\nexports.isRunTree = isRunTree;\nexports.isRunnableConfigLike = isRunnableConfigLike;\nconst client_js_1 = require(\"./client.cjs\");\nconst env_js_1 = require(\"./env.cjs\");\nconst error_js_1 = require(\"./utils/error.cjs\");\nconst constants_js_1 = require(\"./singletons/constants.cjs\");\nconst context_vars_js_1 = require(\"./utils/context_vars.cjs\");\nconst env_js_2 = require(\"./utils/env.cjs\");\nconst project_js_1 = require(\"./utils/project.cjs\");\nconst env_js_3 = require(\"./utils/env.cjs\");\nconst warn_js_1 = require(\"./utils/warn.cjs\");\nconst _uuid_js_1 = require(\"./utils/_uuid.cjs\");\nconst uuid_1 = require(\"uuid\");\nconst TIMESTAMP_LENGTH = 36;\n// DNS namespace for UUID v5 (same as Python's uuid.NAMESPACE_DNS)\nconst UUID_NAMESPACE_DNS = \"6ba7b810-9dad-11d1-80b4-00c04fd430c8\";\nfunction getReplicaKey(replica) {\n // Generate a unique key by hashing the replica's identifying properties\n // This ensures each unique replica (combination of projectName, apiUrl, workspaceId, apiKey) gets a unique key\n // Sort keys to ensure consistent hashing\n const sortedKeys = Object.keys(replica).sort();\n const keyData = sortedKeys\n .map((key) => `${key}:${replica[key] ?? \"\"}`)\n .join(\"|\");\n return (0, uuid_1.v5)(keyData, UUID_NAMESPACE_DNS);\n}\nfunction stripNonAlphanumeric(input) {\n return input.replace(/[-:.]/g, \"\");\n}\nfunction getMicrosecondPrecisionDatestring(epoch, executionOrder = 1) {\n // Date only has millisecond precision, so we use the microseconds to break\n // possible ties, avoiding incorrect run order\n const paddedOrder = executionOrder.toFixed(0).slice(0, 3).padStart(3, \"0\");\n return `${new Date(epoch).toISOString().slice(0, -1)}${paddedOrder}Z`;\n}\nfunction convertToDottedOrderFormat(epoch, runId, executionOrder = 1) {\n const microsecondPrecisionDatestring = getMicrosecondPrecisionDatestring(epoch, executionOrder);\n return {\n dottedOrder: stripNonAlphanumeric(microsecondPrecisionDatestring) + runId,\n microsecondPrecisionDatestring,\n };\n}\n/**\n * Baggage header information\n */\nclass Baggage {\n constructor(metadata, tags, project_name, replicas) {\n Object.defineProperty(this, \"metadata\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"tags\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"project_name\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"replicas\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.metadata = metadata;\n this.tags = tags;\n this.project_name = project_name;\n this.replicas = replicas;\n }\n static fromHeader(value) {\n const items = value.split(\",\");\n let metadata = {};\n let tags = [];\n let project_name;\n let replicas;\n for (const item of items) {\n const [key, uriValue] = item.split(\"=\");\n const value = decodeURIComponent(uriValue);\n if (key === \"langsmith-metadata\") {\n metadata = JSON.parse(value);\n }\n else if (key === \"langsmith-tags\") {\n tags = value.split(\",\");\n }\n else if (key === \"langsmith-project\") {\n project_name = value;\n }\n else if (key === \"langsmith-replicas\") {\n replicas = JSON.parse(value);\n }\n }\n return new Baggage(metadata, tags, project_name, replicas);\n }\n toHeader() {\n const items = [];\n if (this.metadata && Object.keys(this.metadata).length > 0) {\n items.push(`langsmith-metadata=${encodeURIComponent(JSON.stringify(this.metadata))}`);\n }\n if (this.tags && this.tags.length > 0) {\n items.push(`langsmith-tags=${encodeURIComponent(this.tags.join(\",\"))}`);\n }\n if (this.project_name) {\n items.push(`langsmith-project=${encodeURIComponent(this.project_name)}`);\n }\n return items.join(\",\");\n }\n}\nclass RunTree {\n constructor(originalConfig) {\n Object.defineProperty(this, \"id\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"name\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"run_type\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"project_name\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"parent_run\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"parent_run_id\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"child_runs\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"start_time\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"end_time\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"extra\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"tags\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"error\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"serialized\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"inputs\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"outputs\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"reference_example_id\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"client\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"events\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"trace_id\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"dotted_order\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"tracingEnabled\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"execution_order\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"child_execution_order\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n /**\n * Attachments associated with the run.\n * Each entry is a tuple of [mime_type, bytes]\n */\n Object.defineProperty(this, \"attachments\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n /**\n * Projects to replicate this run to with optional updates.\n */\n Object.defineProperty(this, \"replicas\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"distributedParentId\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"_serialized_start_time\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n // If you pass in a run tree directly, return a shallow clone\n if (isRunTree(originalConfig)) {\n Object.assign(this, { ...originalConfig });\n return;\n }\n const defaultConfig = RunTree.getDefaultConfig();\n const { metadata, ...config } = originalConfig;\n const client = config.client ?? RunTree.getSharedClient();\n const dedupedMetadata = {\n ...metadata,\n ...config?.extra?.metadata,\n };\n config.extra = { ...config.extra, metadata: dedupedMetadata };\n if (\"id\" in config && config.id == null) {\n delete config.id;\n }\n Object.assign(this, { ...defaultConfig, ...config, client });\n this.execution_order ??= 1;\n this.child_execution_order ??= 1;\n // Generate serialized start time for ID generation\n if (!this.dotted_order) {\n this._serialized_start_time = getMicrosecondPrecisionDatestring(this.start_time, this.execution_order);\n }\n // Generate id from serialized start_time if not provided\n if (!this.id) {\n this.id = (0, _uuid_js_1.uuid7FromTime)(this._serialized_start_time ?? this.start_time);\n }\n if (!this.trace_id) {\n if (this.parent_run) {\n this.trace_id = this.parent_run.trace_id ?? this.id;\n }\n else {\n this.trace_id = this.id;\n }\n }\n this.replicas = _ensureWriteReplicas(this.replicas);\n // Now set the dotted order with the actual ID\n if (!this.dotted_order) {\n const { dottedOrder } = convertToDottedOrderFormat(this.start_time, this.id, this.execution_order);\n if (this.parent_run) {\n this.dotted_order = this.parent_run.dotted_order + \".\" + dottedOrder;\n }\n else {\n this.dotted_order = dottedOrder;\n }\n }\n }\n set metadata(metadata) {\n this.extra = {\n ...this.extra,\n metadata: {\n ...this.extra?.metadata,\n ...metadata,\n },\n };\n }\n get metadata() {\n return this.extra?.metadata;\n }\n static getDefaultConfig() {\n const start_time = Date.now();\n return {\n run_type: \"chain\",\n project_name: (0, project_js_1.getDefaultProjectName)(),\n child_runs: [],\n api_url: (0, env_js_2.getEnvironmentVariable)(\"LANGCHAIN_ENDPOINT\") ?? \"http://localhost:1984\",\n api_key: (0, env_js_2.getEnvironmentVariable)(\"LANGCHAIN_API_KEY\"),\n caller_options: {},\n start_time,\n serialized: {},\n inputs: {},\n extra: {},\n };\n }\n static getSharedClient() {\n if (!RunTree.sharedClient) {\n RunTree.sharedClient = new client_js_1.Client();\n }\n return RunTree.sharedClient;\n }\n createChild(config) {\n const child_execution_order = this.child_execution_order + 1;\n // Handle replicas: if child has its own replicas, use those; otherwise inherit parent's (with reroot stripped)\n // Reroot should only apply to the run where it's explicitly configured, not propagate down\n const inheritedReplicas = this.replicas?.map((replica) => {\n const { reroot, ...rest } = replica;\n return rest;\n });\n const childReplicas = config.replicas ?? inheritedReplicas;\n const child = new RunTree({\n ...config,\n parent_run: this,\n project_name: this.project_name,\n replicas: childReplicas,\n client: this.client,\n tracingEnabled: this.tracingEnabled,\n execution_order: child_execution_order,\n child_execution_order: child_execution_order,\n });\n // Copy context vars over into the new run tree.\n if (constants_js_1._LC_CONTEXT_VARIABLES_KEY in this) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n child[constants_js_1._LC_CONTEXT_VARIABLES_KEY] =\n this[constants_js_1._LC_CONTEXT_VARIABLES_KEY];\n }\n const LC_CHILD = Symbol.for(\"lc:child_config\");\n const presentConfig = config.extra?.[LC_CHILD] ??\n this.extra[LC_CHILD];\n // tracing for LangChain is defined by the _parentRunId and runMap of the tracer\n if (isRunnableConfigLike(presentConfig)) {\n const newConfig = { ...presentConfig };\n const callbacks = isCallbackManagerLike(newConfig.callbacks)\n ? newConfig.callbacks.copy?.()\n : undefined;\n if (callbacks) {\n // update the parent run id\n Object.assign(callbacks, { _parentRunId: child.id });\n // only populate if we're in a newer LC.JS version\n callbacks.handlers\n ?.find(isLangChainTracerLike)\n ?.updateFromRunTree?.(child);\n newConfig.callbacks = callbacks;\n }\n child.extra[LC_CHILD] = newConfig;\n }\n // propagate child_execution_order upwards\n const visited = new Set();\n let current = this;\n while (current != null && !visited.has(current.id)) {\n visited.add(current.id);\n current.child_execution_order = Math.max(current.child_execution_order, child_execution_order);\n current = current.parent_run;\n }\n this.child_runs.push(child);\n return child;\n }\n async end(outputs, error, endTime = Date.now(), metadata) {\n this.outputs = this.outputs ?? outputs;\n this.error = this.error ?? error;\n this.end_time = this.end_time ?? endTime;\n if (metadata && Object.keys(metadata).length > 0) {\n this.extra = this.extra\n ? { ...this.extra, metadata: { ...this.extra.metadata, ...metadata } }\n : { metadata };\n }\n }\n _convertToCreate(run, runtimeEnv, excludeChildRuns = true) {\n const runExtra = run.extra ?? {};\n // Avoid overwriting the runtime environment if it's already set\n if (runExtra?.runtime?.library === undefined) {\n if (!runExtra.runtime) {\n runExtra.runtime = {};\n }\n if (runtimeEnv) {\n for (const [k, v] of Object.entries(runtimeEnv)) {\n if (!runExtra.runtime[k]) {\n runExtra.runtime[k] = v;\n }\n }\n }\n }\n let child_runs;\n let parent_run_id;\n if (!excludeChildRuns) {\n child_runs = run.child_runs.map((child_run) => this._convertToCreate(child_run, runtimeEnv, excludeChildRuns));\n parent_run_id = undefined;\n }\n else {\n parent_run_id = run.parent_run?.id ?? run.parent_run_id;\n child_runs = [];\n }\n return {\n id: run.id,\n name: run.name,\n start_time: run._serialized_start_time ?? run.start_time,\n end_time: run.end_time,\n run_type: run.run_type,\n reference_example_id: run.reference_example_id,\n extra: runExtra,\n serialized: run.serialized,\n error: run.error,\n inputs: run.inputs,\n outputs: run.outputs,\n session_name: run.project_name,\n child_runs: child_runs,\n parent_run_id: parent_run_id,\n trace_id: run.trace_id,\n dotted_order: run.dotted_order,\n tags: run.tags,\n attachments: run.attachments,\n events: run.events,\n };\n }\n _sliceParentId(parentId, run) {\n /**\n * Slice the parent id from dotted order.\n * Additionally check if the current run is a child of the parent. If so, update\n * the parent_run_id to undefined, and set the trace id to the new root id after\n * parent_id.\n */\n if (run.dotted_order) {\n const segs = run.dotted_order.split(\".\");\n let startIdx = null;\n // Find the index of the parent ID in the dotted order\n for (let idx = 0; idx < segs.length; idx++) {\n const segId = segs[idx].slice(-TIMESTAMP_LENGTH);\n if (segId === parentId) {\n startIdx = idx;\n break;\n }\n }\n if (startIdx !== null) {\n // Trim segments to start after parent_id (exclusive)\n const trimmedSegs = segs.slice(startIdx + 1);\n // Rebuild dotted_order\n run.dotted_order = trimmedSegs.join(\".\");\n if (trimmedSegs.length > 0) {\n run.trace_id = trimmedSegs[0].slice(-TIMESTAMP_LENGTH);\n }\n else {\n run.trace_id = run.id;\n }\n }\n }\n if (run.parent_run_id === parentId) {\n // We've found the new root node.\n run.parent_run_id = undefined;\n }\n }\n _setReplicaTraceRoot(replicaKey, traceRootId) {\n // Set the replica trace root in context vars on this run and all descendants\n const replicaTraceRoots = (0, context_vars_js_1.getContextVar)(this, constants_js_1._REPLICA_TRACE_ROOTS_KEY) ?? {};\n replicaTraceRoots[replicaKey] = traceRootId;\n (0, context_vars_js_1.setContextVar)(this, constants_js_1._REPLICA_TRACE_ROOTS_KEY, replicaTraceRoots);\n // Recursively update all descendants to avoid race conditions\n // around run tree creation vs processing time\n for (const child of this.child_runs) {\n child._setReplicaTraceRoot(replicaKey, traceRootId);\n }\n }\n _remapForProject(params) {\n const { projectName, runtimeEnv, excludeChildRuns = true, reroot = false, distributedParentId, apiUrl, apiKey, workspaceId, } = params;\n const baseRun = this._convertToCreate(this, runtimeEnv, excludeChildRuns);\n // Skip remapping if project name is the same\n if (projectName === this.project_name) {\n return {\n ...baseRun,\n session_name: projectName,\n };\n }\n // Apply reroot logic before ID remapping\n if (reroot) {\n if (distributedParentId) {\n // If we have a distributed parent ID, slice at that point\n this._sliceParentId(distributedParentId, baseRun);\n }\n else {\n // If no distributed parent ID, simply make this run a root run\n // by removing parent_run_id and resetting trace info\n baseRun.parent_run_id = undefined;\n // Keep the current run as the trace root\n if (baseRun.dotted_order) {\n // Reset dotted order to just this run\n const segs = baseRun.dotted_order.split(\".\");\n if (segs.length > 0) {\n baseRun.dotted_order = segs[segs.length - 1];\n baseRun.trace_id = baseRun.id;\n }\n }\n }\n // Store this run's original ID in context vars so descendants know the new trace root\n // We store the original ID (before remapping) so it can be found in dotted_order\n const replicaKey = getReplicaKey({\n projectName,\n apiUrl,\n apiKey,\n workspaceId,\n });\n this._setReplicaTraceRoot(replicaKey, baseRun.id);\n }\n // If an ancestor was rerooted for this replica, update trace_id and dotted_order\n // to reflect the new trace hierarchy. This is tracked via context variables.\n let ancestorRerootedTraceId;\n if (!reroot) {\n const replicaTraceRoots = (0, context_vars_js_1.getContextVar)(this, constants_js_1._REPLICA_TRACE_ROOTS_KEY) ?? {};\n const replicaKey = getReplicaKey({\n projectName,\n apiUrl,\n apiKey,\n workspaceId,\n });\n ancestorRerootedTraceId = replicaTraceRoots[replicaKey];\n if (ancestorRerootedTraceId) {\n // An ancestor was rerooted for this replica, so set our trace_id\n // to the ancestor's original (unmapped) ID. It will be remapped along with other IDs.\n baseRun.trace_id = ancestorRerootedTraceId;\n // Also slice the dotted_order to start from the new trace root\n // This ensures descendants of a rerooted ancestor have correct hierarchy\n if (baseRun.dotted_order) {\n const segs = baseRun.dotted_order.split(\".\");\n let rootIdx = null;\n // Find the new trace root's segment in dotted_order\n for (let idx = 0; idx < segs.length; idx++) {\n const segId = segs[idx].slice(-TIMESTAMP_LENGTH);\n if (segId === ancestorRerootedTraceId) {\n rootIdx = idx;\n break;\n }\n }\n if (rootIdx !== null) {\n // Keep segments from new trace root onwards\n const trimmedSegs = segs.slice(rootIdx);\n baseRun.dotted_order = trimmedSegs.join(\".\");\n }\n }\n }\n }\n // Remap IDs for the replica using uuid5 (deterministic)\n // This ensures consistency across runs in the same replica\n const oldId = baseRun.id;\n const newId = (0, uuid_1.v5)(`${oldId}:${projectName}`, UUID_NAMESPACE_DNS);\n // Remap trace_id\n let newTraceId;\n if (baseRun.trace_id) {\n newTraceId = (0, uuid_1.v5)(`${baseRun.trace_id}:${projectName}`, UUID_NAMESPACE_DNS);\n }\n else {\n newTraceId = newId;\n }\n // Remap parent_run_id\n let newParentId;\n if (baseRun.parent_run_id) {\n newParentId = (0, uuid_1.v5)(`${baseRun.parent_run_id}:${projectName}`, UUID_NAMESPACE_DNS);\n }\n // Remap dotted_order segments\n let newDottedOrder;\n if (baseRun.dotted_order) {\n const segs = baseRun.dotted_order.split(\".\");\n const remappedSegs = segs.map((seg) => {\n // Extract the UUID from the segment (last TIMESTAMP_LENGTH characters)\n const segId = seg.slice(-TIMESTAMP_LENGTH);\n const remappedId = (0, uuid_1.v5)(`${segId}:${projectName}`, UUID_NAMESPACE_DNS);\n // Replace the UUID part while keeping the timestamp prefix\n return seg.slice(0, -TIMESTAMP_LENGTH) + remappedId;\n });\n newDottedOrder = remappedSegs.join(\".\");\n }\n return {\n ...baseRun,\n id: newId,\n trace_id: newTraceId,\n parent_run_id: newParentId,\n dotted_order: newDottedOrder,\n session_name: projectName,\n };\n }\n async postRun(excludeChildRuns = true) {\n try {\n const runtimeEnv = (0, env_js_2.getRuntimeEnvironment)();\n if (this.replicas && this.replicas.length > 0) {\n for (const { projectName, apiKey, apiUrl, workspaceId, reroot } of this\n .replicas) {\n const runCreate = this._remapForProject({\n projectName: projectName ?? this.project_name,\n runtimeEnv,\n excludeChildRuns: true,\n reroot,\n distributedParentId: this.distributedParentId,\n apiUrl,\n apiKey,\n workspaceId,\n });\n await this.client.createRun(runCreate, {\n apiKey,\n apiUrl,\n workspaceId,\n });\n }\n }\n else {\n const runCreate = this._convertToCreate(this, runtimeEnv, excludeChildRuns);\n await this.client.createRun(runCreate);\n }\n if (!excludeChildRuns) {\n (0, warn_js_1.warnOnce)(\"Posting with excludeChildRuns=false is deprecated and will be removed in a future version.\");\n for (const childRun of this.child_runs) {\n await childRun.postRun(false);\n }\n }\n }\n catch (error) {\n console.error(`Error in postRun for run ${this.id}:`, error);\n }\n }\n async patchRun(options) {\n if (this.replicas && this.replicas.length > 0) {\n for (const { projectName, apiKey, apiUrl, workspaceId, updates, reroot, } of this.replicas) {\n const runData = this._remapForProject({\n projectName: projectName ?? this.project_name,\n runtimeEnv: undefined,\n excludeChildRuns: true,\n reroot,\n distributedParentId: this.distributedParentId,\n apiUrl,\n apiKey,\n workspaceId,\n });\n const updatePayload = {\n id: runData.id,\n name: runData.name,\n run_type: runData.run_type,\n start_time: runData.start_time,\n outputs: runData.outputs,\n error: runData.error,\n parent_run_id: runData.parent_run_id,\n session_name: runData.session_name,\n reference_example_id: runData.reference_example_id,\n end_time: runData.end_time,\n dotted_order: runData.dotted_order,\n trace_id: runData.trace_id,\n events: runData.events,\n tags: runData.tags,\n extra: runData.extra,\n attachments: this.attachments,\n ...updates,\n };\n // Important that inputs is not a key in the run update\n // if excluded because it will overwrite the run create if the\n // two operations are merged during batching\n if (!options?.excludeInputs) {\n updatePayload.inputs = runData.inputs;\n }\n await this.client.updateRun(runData.id, updatePayload, {\n apiKey,\n apiUrl,\n workspaceId,\n });\n }\n }\n else {\n try {\n const runUpdate = {\n name: this.name,\n run_type: this.run_type,\n start_time: this._serialized_start_time ?? this.start_time,\n end_time: this.end_time,\n error: this.error,\n outputs: this.outputs,\n parent_run_id: this.parent_run?.id ?? this.parent_run_id,\n reference_example_id: this.reference_example_id,\n extra: this.extra,\n events: this.events,\n dotted_order: this.dotted_order,\n trace_id: this.trace_id,\n tags: this.tags,\n attachments: this.attachments,\n session_name: this.project_name,\n };\n // Important that inputs is not a key in the run update\n // if excluded because it will overwrite the run create if the\n // two operations are merged during batching\n if (!options?.excludeInputs) {\n runUpdate.inputs = this.inputs;\n }\n await this.client.updateRun(this.id, runUpdate);\n }\n catch (error) {\n console.error(`Error in patchRun for run ${this.id}`, error);\n }\n }\n }\n toJSON() {\n return this._convertToCreate(this, undefined, false);\n }\n /**\n * Add an event to the run tree.\n * @param event - A single event or string to add\n */\n addEvent(event) {\n if (!this.events) {\n this.events = [];\n }\n if (typeof event === \"string\") {\n this.events.push({\n name: \"event\",\n time: new Date().toISOString(),\n message: event,\n });\n }\n else {\n this.events.push({\n ...event,\n time: event.time ?? new Date().toISOString(),\n });\n }\n }\n static fromRunnableConfig(parentConfig, props) {\n // We only handle the callback manager case for now\n const callbackManager = parentConfig?.callbacks;\n let parentRun;\n let projectName;\n let client;\n let tracingEnabled = (0, env_js_1.isTracingEnabled)();\n if (callbackManager) {\n const parentRunId = callbackManager?.getParentRunId?.() ?? \"\";\n const langChainTracer = callbackManager?.handlers?.find((handler) => handler?.name == \"langchain_tracer\");\n parentRun = langChainTracer?.getRun?.(parentRunId);\n projectName = langChainTracer?.projectName;\n client = langChainTracer?.client;\n tracingEnabled = tracingEnabled || !!langChainTracer;\n }\n if (!parentRun) {\n return new RunTree({\n ...props,\n client,\n tracingEnabled,\n project_name: projectName,\n });\n }\n const parentRunTree = new RunTree({\n name: parentRun.name,\n id: parentRun.id,\n trace_id: parentRun.trace_id,\n dotted_order: parentRun.dotted_order,\n client,\n tracingEnabled,\n project_name: projectName,\n tags: [\n ...new Set((parentRun?.tags ?? []).concat(parentConfig?.tags ?? [])),\n ],\n extra: {\n metadata: {\n ...parentRun?.extra?.metadata,\n ...parentConfig?.metadata,\n },\n },\n });\n return parentRunTree.createChild(props);\n }\n static fromDottedOrder(dottedOrder) {\n return this.fromHeaders({ \"langsmith-trace\": dottedOrder });\n }\n static fromHeaders(headers, inheritArgs) {\n const rawHeaders = \"get\" in headers && typeof headers.get === \"function\"\n ? {\n \"langsmith-trace\": headers.get(\"langsmith-trace\"),\n baggage: headers.get(\"baggage\"),\n }\n : headers;\n const headerTrace = rawHeaders[\"langsmith-trace\"];\n if (!headerTrace || typeof headerTrace !== \"string\")\n return undefined;\n const parentDottedOrder = headerTrace.trim();\n const parsedDottedOrder = parentDottedOrder.split(\".\").map((part) => {\n const [strTime, uuid] = part.split(\"Z\");\n return { strTime, time: Date.parse(strTime + \"Z\"), uuid };\n });\n const traceId = parsedDottedOrder[0].uuid;\n const config = {\n ...inheritArgs,\n name: inheritArgs?.[\"name\"] ?? \"parent\",\n run_type: inheritArgs?.[\"run_type\"] ?? \"chain\",\n start_time: inheritArgs?.[\"start_time\"] ?? Date.now(),\n id: parsedDottedOrder.at(-1)?.uuid,\n trace_id: traceId,\n dotted_order: parentDottedOrder,\n };\n if (rawHeaders[\"baggage\"] && typeof rawHeaders[\"baggage\"] === \"string\") {\n const baggage = Baggage.fromHeader(rawHeaders[\"baggage\"]);\n config.metadata = baggage.metadata;\n config.tags = baggage.tags;\n config.project_name = baggage.project_name;\n config.replicas = baggage.replicas;\n }\n const runTree = new RunTree(config);\n // Set the distributed parent ID to this run's ID for rerooting\n runTree.distributedParentId = runTree.id;\n return runTree;\n }\n toHeaders(headers) {\n const result = {\n \"langsmith-trace\": this.dotted_order,\n baggage: new Baggage(this.extra?.metadata, this.tags, this.project_name, this.replicas).toHeader(),\n };\n if (headers) {\n for (const [key, value] of Object.entries(result)) {\n headers.set(key, value);\n }\n }\n return result;\n }\n}\nexports.RunTree = RunTree;\nObject.defineProperty(RunTree, \"sharedClient\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: null\n});\nfunction isRunTree(x) {\n return (x != null &&\n typeof x.createChild === \"function\" &&\n typeof x.postRun === \"function\");\n}\nfunction isLangChainTracerLike(x) {\n return (typeof x === \"object\" &&\n x != null &&\n typeof x.name === \"string\" &&\n x.name === \"langchain_tracer\");\n}\nfunction containsLangChainTracerLike(x) {\n return (Array.isArray(x) && x.some((callback) => isLangChainTracerLike(callback)));\n}\nfunction isCallbackManagerLike(x) {\n return (typeof x === \"object\" &&\n x != null &&\n Array.isArray(x.handlers));\n}\nfunction isRunnableConfigLike(x) {\n // Check that it's an object with a callbacks arg\n // that has either a CallbackManagerLike object with a langchain tracer within it\n // or an array with a LangChainTracerLike object within it\n const callbacks = x?.callbacks;\n return (x != null &&\n typeof callbacks === \"object\" &&\n // Callback manager with a langchain tracer\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (containsLangChainTracerLike(callbacks?.handlers) ||\n // Or it's an array with a LangChainTracerLike object within it\n containsLangChainTracerLike(callbacks)));\n}\nfunction _getWriteReplicasFromEnv() {\n const envVar = (0, env_js_2.getEnvironmentVariable)(\"LANGSMITH_RUNS_ENDPOINTS\");\n if (!envVar)\n return [];\n try {\n const parsed = JSON.parse(envVar);\n if (Array.isArray(parsed)) {\n const replicas = [];\n for (const item of parsed) {\n if (typeof item !== \"object\" || item === null) {\n console.warn(`Invalid item type in LANGSMITH_RUNS_ENDPOINTS: ` +\n `expected object, got ${typeof item}`);\n continue;\n }\n if (typeof item.api_url !== \"string\") {\n console.warn(`Invalid api_url type in LANGSMITH_RUNS_ENDPOINTS: ` +\n `expected string, got ${typeof item.api_url}`);\n continue;\n }\n if (typeof item.api_key !== \"string\") {\n console.warn(`Invalid api_key type in LANGSMITH_RUNS_ENDPOINTS: ` +\n `expected string, got ${typeof item.api_key}`);\n continue;\n }\n replicas.push({\n apiUrl: item.api_url.replace(/\\/$/, \"\"),\n apiKey: item.api_key,\n });\n }\n return replicas;\n }\n else if (typeof parsed === \"object\" && parsed !== null) {\n _checkEndpointEnvUnset(parsed);\n const replicas = [];\n for (const [url, key] of Object.entries(parsed)) {\n const cleanUrl = url.replace(/\\/$/, \"\");\n if (typeof key === \"string\") {\n replicas.push({\n apiUrl: cleanUrl,\n apiKey: key,\n });\n }\n else {\n console.warn(`Invalid value type in LANGSMITH_RUNS_ENDPOINTS for URL ${url}: ` +\n `expected string, got ${typeof key}`);\n continue;\n }\n }\n return replicas;\n }\n else {\n console.warn(\"Invalid LANGSMITH_RUNS_ENDPOINTS – must be valid JSON array of \" +\n `objects with api_url and api_key properties, or object mapping url->apiKey, got ${typeof parsed}`);\n return [];\n }\n }\n catch (e) {\n if ((0, error_js_1.isConflictingEndpointsError)(e)) {\n throw e;\n }\n console.warn(\"Invalid LANGSMITH_RUNS_ENDPOINTS – must be valid JSON array of \" +\n \"objects with api_url and api_key properties, or object mapping url->apiKey\");\n return [];\n }\n}\nfunction _ensureWriteReplicas(replicas) {\n // If null -> fetch from env\n if (replicas) {\n return replicas.map((replica) => {\n if (Array.isArray(replica)) {\n return {\n projectName: replica[0],\n updates: replica[1],\n };\n }\n return replica;\n });\n }\n return _getWriteReplicasFromEnv();\n}\nfunction _checkEndpointEnvUnset(parsed) {\n if (Object.keys(parsed).length > 0 &&\n (0, env_js_3.getLangSmithEnvironmentVariable)(\"ENDPOINT\")) {\n throw new error_js_1.ConflictingEndpointsError();\n }\n}\n","module.exports = require('./dist/run_trees.cjs');","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BaseTracer = void 0;\nexports.isBaseTracer = isBaseTracer;\nconst run_trees_1 = require(\"langsmith/run_trees\");\nconst base_js_1 = require(\"../callbacks/base.cjs\");\nconst env_js_1 = require(\"../utils/env.cjs\");\n// TODO: Remove and just use base LangSmith Run type\nconst convertRunTreeToRun = (runTree) => {\n if (!runTree) {\n return undefined;\n }\n // Important that we return the raw run tree object since the reference\n // is mutated in other places.\n // TODO: Remove places where this is being done.\n // eslint-disable-next-line no-param-reassign\n runTree.events = runTree.events ?? [];\n // eslint-disable-next-line no-param-reassign\n runTree.child_runs = runTree.child_runs ?? [];\n // TODO: Remove this cast and just use the LangSmith RunTree type.\n return runTree;\n};\nfunction convertRunToRunTree(run, parentRun) {\n if (!run) {\n return undefined;\n }\n return new run_trees_1.RunTree({\n ...run,\n start_time: run._serialized_start_time ?? run.start_time,\n parent_run: convertRunToRunTree(parentRun),\n child_runs: run.child_runs\n .map((r) => convertRunToRunTree(r))\n .filter((r) => r !== undefined),\n extra: {\n ...run.extra,\n runtime: (0, env_js_1.getRuntimeEnvironmentSync)(),\n },\n tracingEnabled: false,\n });\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _coerceToDict(value, defaultKey) {\n return value && !Array.isArray(value) && typeof value === \"object\"\n ? value\n : { [defaultKey]: value };\n}\nfunction isBaseTracer(x) {\n return typeof x._addRunToRunMap === \"function\";\n}\nclass BaseTracer extends base_js_1.BaseCallbackHandler {\n constructor(_fields) {\n super(...arguments);\n /** @deprecated Use `runTreeMap` instead. */\n Object.defineProperty(this, \"runMap\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: new Map()\n });\n Object.defineProperty(this, \"runTreeMap\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: new Map()\n });\n Object.defineProperty(this, \"usesRunTreeMap\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n }\n copy() {\n return this;\n }\n getRunById(runId) {\n if (runId === undefined) {\n return undefined;\n }\n return this.usesRunTreeMap\n ? convertRunTreeToRun(this.runTreeMap.get(runId))\n : this.runMap.get(runId);\n }\n stringifyError(error) {\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (error instanceof Error) {\n return error.message + (error?.stack ? `\\n\\n${error.stack}` : \"\");\n }\n if (typeof error === \"string\") {\n return error;\n }\n return `${error}`;\n }\n _addChildRun(parentRun, childRun) {\n parentRun.child_runs.push(childRun);\n }\n _addRunToRunMap(run) {\n const { dottedOrder: currentDottedOrder, microsecondPrecisionDatestring } = (0, run_trees_1.convertToDottedOrderFormat)(new Date(run.start_time).getTime(), run.id, run.execution_order);\n const storedRun = { ...run };\n const parentRun = this.getRunById(storedRun.parent_run_id);\n if (storedRun.parent_run_id !== undefined) {\n if (parentRun) {\n this._addChildRun(parentRun, storedRun);\n parentRun.child_execution_order = Math.max(parentRun.child_execution_order, storedRun.child_execution_order);\n storedRun.trace_id = parentRun.trace_id;\n if (parentRun.dotted_order !== undefined) {\n storedRun.dotted_order = [\n parentRun.dotted_order,\n currentDottedOrder,\n ].join(\".\");\n storedRun._serialized_start_time = microsecondPrecisionDatestring;\n }\n else {\n // This can happen naturally for callbacks added within a run\n // console.debug(`Parent run with UUID ${storedRun.parent_run_id} has no dotted order.`);\n }\n }\n else {\n // This can happen naturally for callbacks added within a run\n // console.debug(\n // `Parent run with UUID ${storedRun.parent_run_id} not found.`\n // );\n }\n }\n else {\n storedRun.trace_id = storedRun.id;\n storedRun.dotted_order = currentDottedOrder;\n storedRun._serialized_start_time = microsecondPrecisionDatestring;\n }\n if (this.usesRunTreeMap) {\n const runTree = convertRunToRunTree(storedRun, parentRun);\n if (runTree !== undefined) {\n this.runTreeMap.set(storedRun.id, runTree);\n }\n }\n else {\n this.runMap.set(storedRun.id, storedRun);\n }\n return storedRun;\n }\n async _endTrace(run) {\n const parentRun = run.parent_run_id !== undefined && this.getRunById(run.parent_run_id);\n if (parentRun) {\n parentRun.child_execution_order = Math.max(parentRun.child_execution_order, run.child_execution_order);\n }\n else {\n await this.persistRun(run);\n }\n await this.onRunUpdate?.(run);\n if (this.usesRunTreeMap) {\n this.runTreeMap.delete(run.id);\n }\n else {\n this.runMap.delete(run.id);\n }\n }\n _getExecutionOrder(parentRunId) {\n const parentRun = parentRunId !== undefined && this.getRunById(parentRunId);\n // If a run has no parent then execution order is 1\n if (!parentRun) {\n return 1;\n }\n return parentRun.child_execution_order + 1;\n }\n /**\n * Create and add a run to the run map for LLM start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForLLMStart(llm, prompts, runId, parentRunId, extraParams, tags, metadata, name) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const finalExtraParams = metadata\n ? { ...extraParams, metadata }\n : extraParams;\n const run = {\n id: runId,\n name: name ?? llm.id[llm.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: llm,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs: { prompts },\n execution_order,\n child_runs: [],\n child_execution_order: execution_order,\n run_type: \"llm\",\n extra: finalExtraParams ?? {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n async handleLLMStart(llm, prompts, runId, parentRunId, extraParams, tags, metadata, name) {\n const run = this.getRunById(runId) ??\n this._createRunForLLMStart(llm, prompts, runId, parentRunId, extraParams, tags, metadata, name);\n await this.onRunCreate?.(run);\n await this.onLLMStart?.(run);\n return run;\n }\n /**\n * Create and add a run to the run map for chat model start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChatModelStart(llm, messages, runId, parentRunId, extraParams, tags, metadata, name) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const finalExtraParams = metadata\n ? { ...extraParams, metadata }\n : extraParams;\n const run = {\n id: runId,\n name: name ?? llm.id[llm.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: llm,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs: { messages },\n execution_order,\n child_runs: [],\n child_execution_order: execution_order,\n run_type: \"llm\",\n extra: finalExtraParams ?? {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n async handleChatModelStart(llm, messages, runId, parentRunId, extraParams, tags, metadata, name) {\n const run = this.getRunById(runId) ??\n this._createRunForChatModelStart(llm, messages, runId, parentRunId, extraParams, tags, metadata, name);\n await this.onRunCreate?.(run);\n await this.onLLMStart?.(run);\n return run;\n }\n async handleLLMEnd(output, runId, _parentRunId, _tags, extraParams) {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"llm\") {\n throw new Error(\"No LLM run to end.\");\n }\n run.end_time = Date.now();\n run.outputs = output;\n run.events.push({\n name: \"end\",\n time: new Date(run.end_time).toISOString(),\n });\n run.extra = { ...run.extra, ...extraParams };\n await this.onLLMEnd?.(run);\n await this._endTrace(run);\n return run;\n }\n async handleLLMError(error, runId, _parentRunId, _tags, extraParams) {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"llm\") {\n throw new Error(\"No LLM run to end.\");\n }\n run.end_time = Date.now();\n run.error = this.stringifyError(error);\n run.events.push({\n name: \"error\",\n time: new Date(run.end_time).toISOString(),\n });\n run.extra = { ...run.extra, ...extraParams };\n await this.onLLMError?.(run);\n await this._endTrace(run);\n return run;\n }\n /**\n * Create and add a run to the run map for chain start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChainStart(chain, inputs, runId, parentRunId, tags, metadata, runType, name) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const run = {\n id: runId,\n name: name ?? chain.id[chain.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: chain,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs,\n execution_order,\n child_execution_order: execution_order,\n run_type: runType ?? \"chain\",\n child_runs: [],\n extra: metadata ? { metadata } : {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n async handleChainStart(chain, inputs, runId, parentRunId, tags, metadata, runType, name) {\n const run = this.getRunById(runId) ??\n this._createRunForChainStart(chain, inputs, runId, parentRunId, tags, metadata, runType, name);\n await this.onRunCreate?.(run);\n await this.onChainStart?.(run);\n return run;\n }\n async handleChainEnd(outputs, runId, _parentRunId, _tags, kwargs) {\n const run = this.getRunById(runId);\n if (!run) {\n throw new Error(\"No chain run to end.\");\n }\n run.end_time = Date.now();\n run.outputs = _coerceToDict(outputs, \"output\");\n run.events.push({\n name: \"end\",\n time: new Date(run.end_time).toISOString(),\n });\n if (kwargs?.inputs !== undefined) {\n run.inputs = _coerceToDict(kwargs.inputs, \"input\");\n }\n await this.onChainEnd?.(run);\n await this._endTrace(run);\n return run;\n }\n async handleChainError(error, runId, _parentRunId, _tags, kwargs) {\n const run = this.getRunById(runId);\n if (!run) {\n throw new Error(\"No chain run to end.\");\n }\n run.end_time = Date.now();\n run.error = this.stringifyError(error);\n run.events.push({\n name: \"error\",\n time: new Date(run.end_time).toISOString(),\n });\n if (kwargs?.inputs !== undefined) {\n run.inputs = _coerceToDict(kwargs.inputs, \"input\");\n }\n await this.onChainError?.(run);\n await this._endTrace(run);\n return run;\n }\n /**\n * Create and add a run to the run map for tool start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForToolStart(tool, input, runId, parentRunId, tags, metadata, name) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const run = {\n id: runId,\n name: name ?? tool.id[tool.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: tool,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs: { input },\n execution_order,\n child_execution_order: execution_order,\n run_type: \"tool\",\n child_runs: [],\n extra: metadata ? { metadata } : {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n async handleToolStart(tool, input, runId, parentRunId, tags, metadata, name) {\n const run = this.getRunById(runId) ??\n this._createRunForToolStart(tool, input, runId, parentRunId, tags, metadata, name);\n await this.onRunCreate?.(run);\n await this.onToolStart?.(run);\n return run;\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n async handleToolEnd(output, runId) {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"tool\") {\n throw new Error(\"No tool run to end\");\n }\n run.end_time = Date.now();\n run.outputs = { output };\n run.events.push({\n name: \"end\",\n time: new Date(run.end_time).toISOString(),\n });\n await this.onToolEnd?.(run);\n await this._endTrace(run);\n return run;\n }\n async handleToolError(error, runId) {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"tool\") {\n throw new Error(\"No tool run to end\");\n }\n run.end_time = Date.now();\n run.error = this.stringifyError(error);\n run.events.push({\n name: \"error\",\n time: new Date(run.end_time).toISOString(),\n });\n await this.onToolError?.(run);\n await this._endTrace(run);\n return run;\n }\n async handleAgentAction(action, runId) {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"chain\") {\n return;\n }\n const agentRun = run;\n agentRun.actions = agentRun.actions || [];\n agentRun.actions.push(action);\n agentRun.events.push({\n name: \"agent_action\",\n time: new Date().toISOString(),\n kwargs: { action },\n });\n await this.onAgentAction?.(run);\n }\n async handleAgentEnd(action, runId) {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"chain\") {\n return;\n }\n run.events.push({\n name: \"agent_end\",\n time: new Date().toISOString(),\n kwargs: { action },\n });\n await this.onAgentEnd?.(run);\n }\n /**\n * Create and add a run to the run map for retriever start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForRetrieverStart(retriever, query, runId, parentRunId, tags, metadata, name) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const run = {\n id: runId,\n name: name ?? retriever.id[retriever.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: retriever,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs: { query },\n execution_order,\n child_execution_order: execution_order,\n run_type: \"retriever\",\n child_runs: [],\n extra: metadata ? { metadata } : {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n async handleRetrieverStart(retriever, query, runId, parentRunId, tags, metadata, name) {\n const run = this.getRunById(runId) ??\n this._createRunForRetrieverStart(retriever, query, runId, parentRunId, tags, metadata, name);\n await this.onRunCreate?.(run);\n await this.onRetrieverStart?.(run);\n return run;\n }\n async handleRetrieverEnd(documents, runId) {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"retriever\") {\n throw new Error(\"No retriever run to end\");\n }\n run.end_time = Date.now();\n run.outputs = { documents };\n run.events.push({\n name: \"end\",\n time: new Date(run.end_time).toISOString(),\n });\n await this.onRetrieverEnd?.(run);\n await this._endTrace(run);\n return run;\n }\n async handleRetrieverError(error, runId) {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"retriever\") {\n throw new Error(\"No retriever run to end\");\n }\n run.end_time = Date.now();\n run.error = this.stringifyError(error);\n run.events.push({\n name: \"error\",\n time: new Date(run.end_time).toISOString(),\n });\n await this.onRetrieverError?.(run);\n await this._endTrace(run);\n return run;\n }\n async handleText(text, runId) {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"chain\") {\n return;\n }\n run.events.push({\n name: \"text\",\n time: new Date().toISOString(),\n kwargs: { text },\n });\n await this.onText?.(run);\n }\n async handleLLMNewToken(token, idx, runId, _parentRunId, _tags, fields) {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"llm\") {\n throw new Error(`Invalid \"runId\" provided to \"handleLLMNewToken\" callback.`);\n }\n run.events.push({\n name: \"new_token\",\n time: new Date().toISOString(),\n kwargs: { token, idx, chunk: fields?.chunk },\n });\n await this.onLLMNewToken?.(run, token, { chunk: fields?.chunk });\n return run;\n }\n}\nexports.BaseTracer = BaseTracer;\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ConsoleCallbackHandler = void 0;\nconst ansi_styles_1 = __importDefault(require(\"ansi-styles\"));\nconst base_js_1 = require(\"./base.cjs\");\nfunction wrap(style, text) {\n return `${style.open}${text}${style.close}`;\n}\nfunction tryJsonStringify(obj, fallback) {\n try {\n return JSON.stringify(obj, null, 2);\n }\n catch (err) {\n return fallback;\n }\n}\nfunction formatKVMapItem(value) {\n if (typeof value === \"string\") {\n return value.trim();\n }\n if (value === null || value === undefined) {\n return value;\n }\n return tryJsonStringify(value, value.toString());\n}\nfunction elapsed(run) {\n if (!run.end_time)\n return \"\";\n const elapsed = run.end_time - run.start_time;\n if (elapsed < 1000) {\n return `${elapsed}ms`;\n }\n return `${(elapsed / 1000).toFixed(2)}s`;\n}\nconst { color } = ansi_styles_1.default;\n/**\n * A tracer that logs all events to the console. It extends from the\n * `BaseTracer` class and overrides its methods to provide custom logging\n * functionality.\n * @example\n * ```typescript\n *\n * const llm = new ChatAnthropic({\n * temperature: 0,\n * tags: [\"example\", \"callbacks\", \"constructor\"],\n * callbacks: [new ConsoleCallbackHandler()],\n * });\n *\n * ```\n */\nclass ConsoleCallbackHandler extends base_js_1.BaseTracer {\n constructor() {\n super(...arguments);\n Object.defineProperty(this, \"name\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: \"console_callback_handler\"\n });\n }\n /**\n * Method used to persist the run. In this case, it simply returns a\n * resolved promise as there's no persistence logic.\n * @param _run The run to persist.\n * @returns A resolved promise.\n */\n persistRun(_run) {\n return Promise.resolve();\n }\n // utility methods\n /**\n * Method used to get all the parent runs of a given run.\n * @param run The run whose parents are to be retrieved.\n * @returns An array of parent runs.\n */\n getParents(run) {\n const parents = [];\n let currentRun = run;\n while (currentRun.parent_run_id) {\n const parent = this.runMap.get(currentRun.parent_run_id);\n if (parent) {\n parents.push(parent);\n currentRun = parent;\n }\n else {\n break;\n }\n }\n return parents;\n }\n /**\n * Method used to get a string representation of the run's lineage, which\n * is used in logging.\n * @param run The run whose lineage is to be retrieved.\n * @returns A string representation of the run's lineage.\n */\n getBreadcrumbs(run) {\n const parents = this.getParents(run).reverse();\n const string = [...parents, run]\n .map((parent, i, arr) => {\n const name = `${parent.execution_order}:${parent.run_type}:${parent.name}`;\n return i === arr.length - 1 ? wrap(ansi_styles_1.default.bold, name) : name;\n })\n .join(\" > \");\n return wrap(color.grey, string);\n }\n // logging methods\n /**\n * Method used to log the start of a chain run.\n * @param run The chain run that has started.\n * @returns void\n */\n onChainStart(run) {\n const crumbs = this.getBreadcrumbs(run);\n console.log(`${wrap(color.green, \"[chain/start]\")} [${crumbs}] Entering Chain run with input: ${tryJsonStringify(run.inputs, \"[inputs]\")}`);\n }\n /**\n * Method used to log the end of a chain run.\n * @param run The chain run that has ended.\n * @returns void\n */\n onChainEnd(run) {\n const crumbs = this.getBreadcrumbs(run);\n console.log(`${wrap(color.cyan, \"[chain/end]\")} [${crumbs}] [${elapsed(run)}] Exiting Chain run with output: ${tryJsonStringify(run.outputs, \"[outputs]\")}`);\n }\n /**\n * Method used to log any errors of a chain run.\n * @param run The chain run that has errored.\n * @returns void\n */\n onChainError(run) {\n const crumbs = this.getBreadcrumbs(run);\n console.log(`${wrap(color.red, \"[chain/error]\")} [${crumbs}] [${elapsed(run)}] Chain run errored with error: ${tryJsonStringify(run.error, \"[error]\")}`);\n }\n /**\n * Method used to log the start of an LLM run.\n * @param run The LLM run that has started.\n * @returns void\n */\n onLLMStart(run) {\n const crumbs = this.getBreadcrumbs(run);\n const inputs = \"prompts\" in run.inputs\n ? { prompts: run.inputs.prompts.map((p) => p.trim()) }\n : run.inputs;\n console.log(`${wrap(color.green, \"[llm/start]\")} [${crumbs}] Entering LLM run with input: ${tryJsonStringify(inputs, \"[inputs]\")}`);\n }\n /**\n * Method used to log the end of an LLM run.\n * @param run The LLM run that has ended.\n * @returns void\n */\n onLLMEnd(run) {\n const crumbs = this.getBreadcrumbs(run);\n console.log(`${wrap(color.cyan, \"[llm/end]\")} [${crumbs}] [${elapsed(run)}] Exiting LLM run with output: ${tryJsonStringify(run.outputs, \"[response]\")}`);\n }\n /**\n * Method used to log any errors of an LLM run.\n * @param run The LLM run that has errored.\n * @returns void\n */\n onLLMError(run) {\n const crumbs = this.getBreadcrumbs(run);\n console.log(`${wrap(color.red, \"[llm/error]\")} [${crumbs}] [${elapsed(run)}] LLM run errored with error: ${tryJsonStringify(run.error, \"[error]\")}`);\n }\n /**\n * Method used to log the start of a tool run.\n * @param run The tool run that has started.\n * @returns void\n */\n onToolStart(run) {\n const crumbs = this.getBreadcrumbs(run);\n console.log(`${wrap(color.green, \"[tool/start]\")} [${crumbs}] Entering Tool run with input: \"${formatKVMapItem(run.inputs.input)}\"`);\n }\n /**\n * Method used to log the end of a tool run.\n * @param run The tool run that has ended.\n * @returns void\n */\n onToolEnd(run) {\n const crumbs = this.getBreadcrumbs(run);\n console.log(`${wrap(color.cyan, \"[tool/end]\")} [${crumbs}] [${elapsed(run)}] Exiting Tool run with output: \"${formatKVMapItem(run.outputs?.output)}\"`);\n }\n /**\n * Method used to log any errors of a tool run.\n * @param run The tool run that has errored.\n * @returns void\n */\n onToolError(run) {\n const crumbs = this.getBreadcrumbs(run);\n console.log(`${wrap(color.red, \"[tool/error]\")} [${crumbs}] [${elapsed(run)}] Tool run errored with error: ${tryJsonStringify(run.error, \"[error]\")}`);\n }\n /**\n * Method used to log the start of a retriever run.\n * @param run The retriever run that has started.\n * @returns void\n */\n onRetrieverStart(run) {\n const crumbs = this.getBreadcrumbs(run);\n console.log(`${wrap(color.green, \"[retriever/start]\")} [${crumbs}] Entering Retriever run with input: ${tryJsonStringify(run.inputs, \"[inputs]\")}`);\n }\n /**\n * Method used to log the end of a retriever run.\n * @param run The retriever run that has ended.\n * @returns void\n */\n onRetrieverEnd(run) {\n const crumbs = this.getBreadcrumbs(run);\n console.log(`${wrap(color.cyan, \"[retriever/end]\")} [${crumbs}] [${elapsed(run)}] Exiting Retriever run with output: ${tryJsonStringify(run.outputs, \"[outputs]\")}`);\n }\n /**\n * Method used to log any errors of a retriever run.\n * @param run The retriever run that has errored.\n * @returns void\n */\n onRetrieverError(run) {\n const crumbs = this.getBreadcrumbs(run);\n console.log(`${wrap(color.red, \"[retriever/error]\")} [${crumbs}] [${elapsed(run)}] Retriever run errored with error: ${tryJsonStringify(run.error, \"[error]\")}`);\n }\n /**\n * Method used to log the action selected by the agent.\n * @param run The run in which the agent action occurred.\n * @returns void\n */\n onAgentAction(run) {\n const agentRun = run;\n const crumbs = this.getBreadcrumbs(run);\n console.log(`${wrap(color.blue, \"[agent/action]\")} [${crumbs}] Agent selected action: ${tryJsonStringify(agentRun.actions[agentRun.actions.length - 1], \"[action]\")}`);\n }\n}\nexports.ConsoleCallbackHandler = ConsoleCallbackHandler;\n","\"use strict\";\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable no-param-reassign */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.addLangChainErrorFields = addLangChainErrorFields;\nfunction addLangChainErrorFields(error, lc_error_code) {\n error.lc_error_code = lc_error_code;\n error.message = `${error.message}\\n\\nTroubleshooting URL: https://js.langchain.com/docs/troubleshooting/errors/${lc_error_code}/\\n`;\n return error;\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ToolInputParsingException = void 0;\nexports._isToolCall = _isToolCall;\nexports._configHasToolCallId = _configHasToolCallId;\nfunction _isToolCall(toolCall) {\n return !!(toolCall &&\n typeof toolCall === \"object\" &&\n \"type\" in toolCall &&\n toolCall.type === \"tool_call\");\n}\nfunction _configHasToolCallId(config) {\n return !!(config &&\n typeof config === \"object\" &&\n \"toolCall\" in config &&\n config.toolCall != null &&\n typeof config.toolCall === \"object\" &&\n \"id\" in config.toolCall &&\n typeof config.toolCall.id === \"string\");\n}\n/**\n * Custom error class used to handle exceptions related to tool input parsing.\n * It extends the built-in `Error` class and adds an optional `output`\n * property that can hold the output that caused the exception.\n */\nclass ToolInputParsingException extends Error {\n constructor(message, output) {\n super(message);\n Object.defineProperty(this, \"output\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.output = output;\n }\n}\nexports.ToolInputParsingException = ToolInputParsingException;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.parseJsonMarkdown = parseJsonMarkdown;\nexports.parsePartialJson = parsePartialJson;\nfunction parseJsonMarkdown(s, parser = parsePartialJson) {\n // eslint-disable-next-line no-param-reassign\n s = s.trim();\n const firstFenceIndex = s.indexOf(\"```\");\n if (firstFenceIndex === -1) {\n return parser(s);\n }\n let contentAfterFence = s.substring(firstFenceIndex + 3);\n if (contentAfterFence.startsWith(\"json\\n\")) {\n contentAfterFence = contentAfterFence.substring(5);\n }\n else if (contentAfterFence.startsWith(\"json\")) {\n contentAfterFence = contentAfterFence.substring(4);\n }\n else if (contentAfterFence.startsWith(\"\\n\")) {\n contentAfterFence = contentAfterFence.substring(1);\n }\n const closingFenceIndex = contentAfterFence.indexOf(\"```\");\n let finalContent = contentAfterFence;\n if (closingFenceIndex !== -1) {\n finalContent = contentAfterFence.substring(0, closingFenceIndex);\n }\n return parser(finalContent.trim());\n}\n// Adapted from https://github.com/KillianLucas/open-interpreter/blob/main/interpreter/core/llm/utils/parse_partial_json.py\n// MIT License\nfunction parsePartialJson(s) {\n // If the input is undefined, return null to indicate failure.\n if (typeof s === \"undefined\") {\n return null;\n }\n // Attempt to parse the string as-is.\n try {\n return JSON.parse(s);\n }\n catch (error) {\n // Pass\n }\n // Initialize variables.\n let new_s = \"\";\n const stack = [];\n let isInsideString = false;\n let escaped = false;\n // Process each character in the string one at a time.\n for (let char of s) {\n if (isInsideString) {\n if (char === '\"' && !escaped) {\n isInsideString = false;\n }\n else if (char === \"\\n\" && !escaped) {\n char = \"\\\\n\"; // Replace the newline character with the escape sequence.\n }\n else if (char === \"\\\\\") {\n escaped = !escaped;\n }\n else {\n escaped = false;\n }\n }\n else {\n if (char === '\"') {\n isInsideString = true;\n escaped = false;\n }\n else if (char === \"{\") {\n stack.push(\"}\");\n }\n else if (char === \"[\") {\n stack.push(\"]\");\n }\n else if (char === \"}\" || char === \"]\") {\n if (stack && stack[stack.length - 1] === char) {\n stack.pop();\n }\n else {\n // Mismatched closing character; the input is malformed.\n return null;\n }\n }\n }\n // Append the processed character to the new string.\n new_s += char;\n }\n // If we're still inside a string at the end of processing,\n // we need to close the string.\n if (isInsideString) {\n new_s += '\"';\n }\n // Close any remaining open structures in the reverse order that they were opened.\n for (let i = stack.length - 1; i >= 0; i -= 1) {\n new_s += stack[i];\n }\n // Attempt to parse the modified string as JSON.\n try {\n return JSON.parse(new_s);\n }\n catch (error) {\n // If we still can't parse the string as JSON, return null to indicate failure.\n return null;\n }\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isDataContentBlock = isDataContentBlock;\nexports.isURLContentBlock = isURLContentBlock;\nexports.isBase64ContentBlock = isBase64ContentBlock;\nexports.isPlainTextContentBlock = isPlainTextContentBlock;\nexports.isIDContentBlock = isIDContentBlock;\nexports.convertToOpenAIImageBlock = convertToOpenAIImageBlock;\nexports.parseMimeType = parseMimeType;\nexports.parseBase64DataUrl = parseBase64DataUrl;\nexports.convertToProviderContentBlock = convertToProviderContentBlock;\nfunction isDataContentBlock(content_block) {\n return (typeof content_block === \"object\" &&\n content_block !== null &&\n \"type\" in content_block &&\n typeof content_block.type === \"string\" &&\n \"source_type\" in content_block &&\n (content_block.source_type === \"url\" ||\n content_block.source_type === \"base64\" ||\n content_block.source_type === \"text\" ||\n content_block.source_type === \"id\"));\n}\nfunction isURLContentBlock(content_block) {\n return (isDataContentBlock(content_block) &&\n content_block.source_type === \"url\" &&\n \"url\" in content_block &&\n typeof content_block.url === \"string\");\n}\nfunction isBase64ContentBlock(content_block) {\n return (isDataContentBlock(content_block) &&\n content_block.source_type === \"base64\" &&\n \"data\" in content_block &&\n typeof content_block.data === \"string\");\n}\nfunction isPlainTextContentBlock(content_block) {\n return (isDataContentBlock(content_block) &&\n content_block.source_type === \"text\" &&\n \"text\" in content_block &&\n typeof content_block.text === \"string\");\n}\nfunction isIDContentBlock(content_block) {\n return (isDataContentBlock(content_block) &&\n content_block.source_type === \"id\" &&\n \"id\" in content_block &&\n typeof content_block.id === \"string\");\n}\nfunction convertToOpenAIImageBlock(content_block) {\n if (isDataContentBlock(content_block)) {\n if (content_block.source_type === \"url\") {\n return {\n type: \"image_url\",\n image_url: {\n url: content_block.url,\n },\n };\n }\n if (content_block.source_type === \"base64\") {\n if (!content_block.mime_type) {\n throw new Error(\"mime_type key is required for base64 data.\");\n }\n const mime_type = content_block.mime_type;\n return {\n type: \"image_url\",\n image_url: {\n url: `data:${mime_type};base64,${content_block.data}`,\n },\n };\n }\n }\n throw new Error(\"Unsupported source type. Only 'url' and 'base64' are supported.\");\n}\n/**\n * Utility function for ChatModelProviders. Parses a mime type into a type, subtype, and parameters.\n *\n * @param mime_type - The mime type to parse.\n * @returns An object containing the type, subtype, and parameters.\n */\nfunction parseMimeType(mime_type) {\n const parts = mime_type.split(\";\")[0].split(\"/\");\n if (parts.length !== 2) {\n throw new Error(`Invalid mime type: \"${mime_type}\" - does not match type/subtype format.`);\n }\n const type = parts[0].trim();\n const subtype = parts[1].trim();\n if (type === \"\" || subtype === \"\") {\n throw new Error(`Invalid mime type: \"${mime_type}\" - type or subtype is empty.`);\n }\n const parameters = {};\n for (const parameterKvp of mime_type.split(\";\").slice(1)) {\n const parameterParts = parameterKvp.split(\"=\");\n if (parameterParts.length !== 2) {\n throw new Error(`Invalid parameter syntax in mime type: \"${mime_type}\".`);\n }\n const key = parameterParts[0].trim();\n const value = parameterParts[1].trim();\n if (key === \"\") {\n throw new Error(`Invalid parameter syntax in mime type: \"${mime_type}\".`);\n }\n parameters[key] = value;\n }\n return {\n type,\n subtype,\n parameters,\n };\n}\n/**\n * Utility function for ChatModelProviders. Parses a base64 data URL into a typed array or string.\n *\n * @param dataUrl - The base64 data URL to parse.\n * @param asTypedArray - Whether to return the data as a typed array.\n * @returns The parsed data and mime type, or undefined if the data URL is invalid.\n */\nfunction parseBase64DataUrl({ dataUrl: data_url, asTypedArray = false, }) {\n const formatMatch = data_url.match(/^data:(\\w+\\/\\w+);base64,([A-Za-z0-9+/]+=*)$/);\n let mime_type;\n if (formatMatch) {\n mime_type = formatMatch[1].toLowerCase();\n const data = asTypedArray\n ? Uint8Array.from(atob(formatMatch[2]), (c) => c.charCodeAt(0))\n : formatMatch[2];\n return {\n mime_type,\n data,\n };\n }\n return undefined;\n}\n/**\n * Convert from a standard data content block to a provider's proprietary data content block format.\n *\n * Don't override this method. Instead, override the more specific conversion methods and use this\n * method unmodified.\n *\n * @param block - The standard data content block to convert.\n * @returns The provider data content block.\n * @throws An error if the standard data content block type is not supported.\n */\nfunction convertToProviderContentBlock(block, converter) {\n if (block.type === \"text\") {\n if (!converter.fromStandardTextBlock) {\n throw new Error(`Converter for ${converter.providerName} does not implement \\`fromStandardTextBlock\\` method.`);\n }\n return converter.fromStandardTextBlock(block);\n }\n if (block.type === \"image\") {\n if (!converter.fromStandardImageBlock) {\n throw new Error(`Converter for ${converter.providerName} does not implement \\`fromStandardImageBlock\\` method.`);\n }\n return converter.fromStandardImageBlock(block);\n }\n if (block.type === \"audio\") {\n if (!converter.fromStandardAudioBlock) {\n throw new Error(`Converter for ${converter.providerName} does not implement \\`fromStandardAudioBlock\\` method.`);\n }\n return converter.fromStandardAudioBlock(block);\n }\n if (block.type === \"file\") {\n if (!converter.fromStandardFileBlock) {\n throw new Error(`Converter for ${converter.providerName} does not implement \\`fromStandardFileBlock\\` method.`);\n }\n return converter.fromStandardFileBlock(block);\n }\n throw new Error(`Unable to convert content block type '${block.type}' to provider-specific format: not recognized.`);\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BaseMessageChunk = exports.BaseMessage = void 0;\nexports.mergeContent = mergeContent;\nexports._mergeStatus = _mergeStatus;\nexports.isOpenAIToolCallArray = isOpenAIToolCallArray;\nexports._mergeDicts = _mergeDicts;\nexports._mergeLists = _mergeLists;\nexports._mergeObj = _mergeObj;\nexports._isMessageFieldWithRole = _isMessageFieldWithRole;\nexports.isBaseMessage = isBaseMessage;\nexports.isBaseMessageChunk = isBaseMessageChunk;\nconst serializable_js_1 = require(\"../load/serializable.cjs\");\nconst content_blocks_js_1 = require(\"./content_blocks.cjs\");\nfunction mergeContent(firstContent, secondContent) {\n // If first content is a string\n if (typeof firstContent === \"string\") {\n if (firstContent === \"\") {\n return secondContent;\n }\n if (typeof secondContent === \"string\") {\n return firstContent + secondContent;\n }\n else if (Array.isArray(secondContent) &&\n secondContent.some((c) => (0, content_blocks_js_1.isDataContentBlock)(c))) {\n return [\n {\n type: \"text\",\n source_type: \"text\",\n text: firstContent,\n },\n ...secondContent,\n ];\n }\n else {\n return [{ type: \"text\", text: firstContent }, ...secondContent];\n }\n // If both are arrays\n }\n else if (Array.isArray(secondContent)) {\n return (_mergeLists(firstContent, secondContent) ?? [\n ...firstContent,\n ...secondContent,\n ]);\n }\n else {\n if (secondContent === \"\") {\n return firstContent;\n }\n else if (Array.isArray(firstContent) &&\n firstContent.some((c) => (0, content_blocks_js_1.isDataContentBlock)(c))) {\n return [\n ...firstContent,\n {\n type: \"file\",\n source_type: \"text\",\n text: secondContent,\n },\n ];\n }\n else {\n return [...firstContent, { type: \"text\", text: secondContent }];\n }\n }\n}\n/**\n * 'Merge' two statuses. If either value passed is 'error', it will return 'error'. Else\n * it will return 'success'.\n *\n * @param {\"success\" | \"error\" | undefined} left The existing value to 'merge' with the new value.\n * @param {\"success\" | \"error\" | undefined} right The new value to 'merge' with the existing value\n * @returns {\"success\" | \"error\"} The 'merged' value.\n */\nfunction _mergeStatus(left, right) {\n if (left === \"error\" || right === \"error\") {\n return \"error\";\n }\n return \"success\";\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction stringifyWithDepthLimit(obj, depthLimit) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n function helper(obj, currentDepth) {\n if (typeof obj !== \"object\" || obj === null || obj === undefined) {\n return obj;\n }\n if (currentDepth >= depthLimit) {\n if (Array.isArray(obj)) {\n return \"[Array]\";\n }\n return \"[Object]\";\n }\n if (Array.isArray(obj)) {\n return obj.map((item) => helper(item, currentDepth + 1));\n }\n const result = {};\n for (const key of Object.keys(obj)) {\n result[key] = helper(obj[key], currentDepth + 1);\n }\n return result;\n }\n return JSON.stringify(helper(obj, 0), null, 2);\n}\n/**\n * Base class for all types of messages in a conversation. It includes\n * properties like `content`, `name`, and `additional_kwargs`. It also\n * includes methods like `toDict()` and `_getType()`.\n */\nclass BaseMessage extends serializable_js_1.Serializable {\n get lc_aliases() {\n // exclude snake case conversion to pascal case\n return {\n additional_kwargs: \"additional_kwargs\",\n response_metadata: \"response_metadata\",\n };\n }\n /**\n * Get text content of the message.\n */\n get text() {\n if (typeof this.content === \"string\") {\n return this.content;\n }\n if (!Array.isArray(this.content))\n return \"\";\n return this.content\n .map((c) => {\n if (typeof c === \"string\")\n return c;\n if (c.type === \"text\")\n return c.text;\n return \"\";\n })\n .join(\"\");\n }\n /** The type of the message. */\n getType() {\n return this._getType();\n }\n constructor(fields, \n /** @deprecated */\n kwargs) {\n if (typeof fields === \"string\") {\n // eslint-disable-next-line no-param-reassign\n fields = {\n content: fields,\n additional_kwargs: kwargs,\n response_metadata: {},\n };\n }\n // Make sure the default value for additional_kwargs is passed into super() for serialization\n if (!fields.additional_kwargs) {\n // eslint-disable-next-line no-param-reassign\n fields.additional_kwargs = {};\n }\n if (!fields.response_metadata) {\n // eslint-disable-next-line no-param-reassign\n fields.response_metadata = {};\n }\n super(fields);\n Object.defineProperty(this, \"lc_namespace\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: [\"langchain_core\", \"messages\"]\n });\n Object.defineProperty(this, \"lc_serializable\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: true\n });\n /** The content of the message. */\n Object.defineProperty(this, \"content\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n /** The name of the message sender in a multi-user chat. */\n Object.defineProperty(this, \"name\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n /** Additional keyword arguments */\n Object.defineProperty(this, \"additional_kwargs\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n /** Response metadata. For example: response headers, logprobs, token counts, model name. */\n Object.defineProperty(this, \"response_metadata\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n /**\n * An optional unique identifier for the message. This should ideally be\n * provided by the provider/model which created the message.\n */\n Object.defineProperty(this, \"id\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.name = fields.name;\n this.content = fields.content;\n this.additional_kwargs = fields.additional_kwargs;\n this.response_metadata = fields.response_metadata;\n this.id = fields.id;\n }\n toDict() {\n return {\n type: this._getType(),\n data: this.toJSON()\n .kwargs,\n };\n }\n static lc_name() {\n return \"BaseMessage\";\n }\n // Can't be protected for silly reasons\n get _printableFields() {\n return {\n id: this.id,\n content: this.content,\n name: this.name,\n additional_kwargs: this.additional_kwargs,\n response_metadata: this.response_metadata,\n };\n }\n // this private method is used to update the ID for the runtime\n // value as well as in lc_kwargs for serialisation\n _updateId(value) {\n this.id = value;\n // lc_attributes wouldn't work here, because jest compares the\n // whole object\n this.lc_kwargs.id = value;\n }\n get [Symbol.toStringTag]() {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return this.constructor.lc_name();\n }\n // Override the default behavior of console.log\n [Symbol.for(\"nodejs.util.inspect.custom\")](depth) {\n if (depth === null) {\n return this;\n }\n const printable = stringifyWithDepthLimit(this._printableFields, Math.max(4, depth));\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return `${this.constructor.lc_name()} ${printable}`;\n }\n}\nexports.BaseMessage = BaseMessage;\nfunction isOpenAIToolCallArray(value) {\n return (Array.isArray(value) &&\n value.every((v) => typeof v.index === \"number\"));\n}\nfunction _mergeDicts(\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nleft, \n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nright\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\n) {\n const merged = { ...left };\n for (const [key, value] of Object.entries(right)) {\n if (merged[key] == null) {\n merged[key] = value;\n }\n else if (value == null) {\n continue;\n }\n else if (typeof merged[key] !== typeof value ||\n Array.isArray(merged[key]) !== Array.isArray(value)) {\n throw new Error(`field[${key}] already exists in the message chunk, but with a different type.`);\n }\n else if (typeof merged[key] === \"string\") {\n if (key === \"type\") {\n // Do not merge 'type' fields\n continue;\n }\n else if ([\"id\", \"name\", \"output_version\", \"model_provider\"].includes(key)) {\n // Keep the incoming value for these fields\n merged[key] = value;\n }\n else {\n merged[key] += value;\n }\n }\n else if (typeof merged[key] === \"object\" && !Array.isArray(merged[key])) {\n merged[key] = _mergeDicts(merged[key], value);\n }\n else if (Array.isArray(merged[key])) {\n merged[key] = _mergeLists(merged[key], value);\n }\n else if (merged[key] === value) {\n continue;\n }\n else {\n console.warn(`field[${key}] already exists in this message chunk and value has unsupported type.`);\n }\n }\n return merged;\n}\nfunction _mergeLists(left, right) {\n if (left === undefined && right === undefined) {\n return undefined;\n }\n else if (left === undefined || right === undefined) {\n return left || right;\n }\n else {\n const merged = [...left];\n for (const item of right) {\n if (typeof item === \"object\" &&\n item !== null &&\n \"index\" in item &&\n typeof item.index === \"number\") {\n const toMerge = merged.findIndex((leftItem) => {\n const isObject = typeof leftItem === \"object\";\n const indiciesMatch = \"index\" in leftItem && leftItem.index === item.index;\n const idsMatch = \"id\" in leftItem && \"id\" in item && leftItem?.id === item?.id;\n const eitherItemMissingID = !(\"id\" in leftItem) ||\n !leftItem?.id ||\n !(\"id\" in item) ||\n !item?.id;\n return isObject && indiciesMatch && (idsMatch || eitherItemMissingID);\n });\n if (toMerge !== -1 &&\n typeof merged[toMerge] === \"object\" &&\n merged[toMerge] !== null) {\n merged[toMerge] = _mergeDicts(merged[toMerge], item);\n }\n else {\n merged.push(item);\n }\n }\n else if (typeof item === \"object\" &&\n item !== null &&\n \"text\" in item &&\n item.text === \"\") {\n // No-op - skip empty text blocks\n continue;\n }\n else {\n merged.push(item);\n }\n }\n return merged;\n }\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _mergeObj(left, right) {\n if (!left && !right) {\n throw new Error(\"Cannot merge two undefined objects.\");\n }\n if (!left || !right) {\n return left || right;\n }\n else if (typeof left !== typeof right) {\n throw new Error(`Cannot merge objects of different types.\\nLeft ${typeof left}\\nRight ${typeof right}`);\n }\n else if (typeof left === \"string\" && typeof right === \"string\") {\n return (left + right);\n }\n else if (Array.isArray(left) && Array.isArray(right)) {\n return _mergeLists(left, right);\n }\n else if (typeof left === \"object\" && typeof right === \"object\") {\n return _mergeDicts(left, right);\n }\n else if (left === right) {\n return left;\n }\n else {\n throw new Error(`Can not merge objects of different types.\\nLeft ${left}\\nRight ${right}`);\n }\n}\n/**\n * Represents a chunk of a message, which can be concatenated with other\n * message chunks. It includes a method `_merge_kwargs_dict()` for merging\n * additional keyword arguments from another `BaseMessageChunk` into this\n * one. It also overrides the `__add__()` method to support concatenation\n * of `BaseMessageChunk` instances.\n */\nclass BaseMessageChunk extends BaseMessage {\n}\nexports.BaseMessageChunk = BaseMessageChunk;\nfunction _isMessageFieldWithRole(x) {\n return typeof x.role === \"string\";\n}\nfunction isBaseMessage(messageLike) {\n return typeof messageLike?._getType === \"function\";\n}\nfunction isBaseMessageChunk(messageLike) {\n return (isBaseMessage(messageLike) &&\n typeof messageLike.concat === \"function\");\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ToolMessageChunk = exports.ToolMessage = void 0;\nexports.isDirectToolOutput = isDirectToolOutput;\nexports.defaultToolCallParser = defaultToolCallParser;\nexports.isToolMessage = isToolMessage;\nexports.isToolMessageChunk = isToolMessageChunk;\nconst base_js_1 = require(\"./base.cjs\");\nfunction isDirectToolOutput(x) {\n return (x != null &&\n typeof x === \"object\" &&\n \"lc_direct_tool_output\" in x &&\n x.lc_direct_tool_output === true);\n}\n/**\n * Represents a tool message in a conversation.\n */\nclass ToolMessage extends base_js_1.BaseMessage {\n static lc_name() {\n return \"ToolMessage\";\n }\n get lc_aliases() {\n // exclude snake case conversion to pascal case\n return { tool_call_id: \"tool_call_id\" };\n }\n constructor(fields, tool_call_id, name) {\n if (typeof fields === \"string\") {\n // eslint-disable-next-line no-param-reassign, @typescript-eslint/no-non-null-assertion\n fields = { content: fields, name, tool_call_id: tool_call_id };\n }\n super(fields);\n Object.defineProperty(this, \"lc_direct_tool_output\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: true\n });\n /**\n * Status of the tool invocation.\n * @version 0.2.19\n */\n Object.defineProperty(this, \"status\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"tool_call_id\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"metadata\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n /**\n * Artifact of the Tool execution which is not meant to be sent to the model.\n *\n * Should only be specified if it is different from the message content, e.g. if only\n * a subset of the full tool output is being passed as message content but the full\n * output is needed in other parts of the code.\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Object.defineProperty(this, \"artifact\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.tool_call_id = fields.tool_call_id;\n this.artifact = fields.artifact;\n this.status = fields.status;\n this.metadata = fields.metadata;\n }\n _getType() {\n return \"tool\";\n }\n static isInstance(message) {\n return message._getType() === \"tool\";\n }\n get _printableFields() {\n return {\n ...super._printableFields,\n tool_call_id: this.tool_call_id,\n artifact: this.artifact,\n };\n }\n}\nexports.ToolMessage = ToolMessage;\n/**\n * Represents a chunk of a tool message, which can be concatenated\n * with other tool message chunks.\n */\nclass ToolMessageChunk extends base_js_1.BaseMessageChunk {\n constructor(fields) {\n super(fields);\n Object.defineProperty(this, \"tool_call_id\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n /**\n * Status of the tool invocation.\n * @version 0.2.19\n */\n Object.defineProperty(this, \"status\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n /**\n * Artifact of the Tool execution which is not meant to be sent to the model.\n *\n * Should only be specified if it is different from the message content, e.g. if only\n * a subset of the full tool output is being passed as message content but the full\n * output is needed in other parts of the code.\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Object.defineProperty(this, \"artifact\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.tool_call_id = fields.tool_call_id;\n this.artifact = fields.artifact;\n this.status = fields.status;\n }\n static lc_name() {\n return \"ToolMessageChunk\";\n }\n _getType() {\n return \"tool\";\n }\n concat(chunk) {\n return new ToolMessageChunk({\n content: (0, base_js_1.mergeContent)(this.content, chunk.content),\n additional_kwargs: (0, base_js_1._mergeDicts)(this.additional_kwargs, chunk.additional_kwargs),\n response_metadata: (0, base_js_1._mergeDicts)(this.response_metadata, chunk.response_metadata),\n artifact: (0, base_js_1._mergeObj)(this.artifact, chunk.artifact),\n tool_call_id: this.tool_call_id,\n id: this.id ?? chunk.id,\n status: (0, base_js_1._mergeStatus)(this.status, chunk.status),\n });\n }\n get _printableFields() {\n return {\n ...super._printableFields,\n tool_call_id: this.tool_call_id,\n artifact: this.artifact,\n };\n }\n}\nexports.ToolMessageChunk = ToolMessageChunk;\nfunction defaultToolCallParser(\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nrawToolCalls) {\n const toolCalls = [];\n const invalidToolCalls = [];\n for (const toolCall of rawToolCalls) {\n if (!toolCall.function) {\n continue;\n }\n else {\n const functionName = toolCall.function.name;\n try {\n const functionArgs = JSON.parse(toolCall.function.arguments);\n const parsed = {\n name: functionName || \"\",\n args: functionArgs || {},\n id: toolCall.id,\n };\n toolCalls.push(parsed);\n }\n catch (error) {\n invalidToolCalls.push({\n name: functionName,\n args: toolCall.function.arguments,\n id: toolCall.id,\n error: \"Malformed args.\",\n });\n }\n }\n }\n return [toolCalls, invalidToolCalls];\n}\nfunction isToolMessage(x) {\n return x._getType() === \"tool\";\n}\nfunction isToolMessageChunk(x) {\n return x._getType() === \"tool\";\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.AIMessageChunk = exports.AIMessage = void 0;\nexports.isAIMessage = isAIMessage;\nexports.isAIMessageChunk = isAIMessageChunk;\nconst json_js_1 = require(\"../utils/json.cjs\");\nconst base_js_1 = require(\"./base.cjs\");\nconst tool_js_1 = require(\"./tool.cjs\");\n/**\n * Represents an AI message in a conversation.\n */\nclass AIMessage extends base_js_1.BaseMessage {\n get lc_aliases() {\n // exclude snake case conversion to pascal case\n return {\n ...super.lc_aliases,\n tool_calls: \"tool_calls\",\n invalid_tool_calls: \"invalid_tool_calls\",\n };\n }\n constructor(fields, \n /** @deprecated */\n kwargs) {\n let initParams;\n if (typeof fields === \"string\") {\n initParams = {\n content: fields,\n tool_calls: [],\n invalid_tool_calls: [],\n additional_kwargs: kwargs ?? {},\n };\n }\n else {\n initParams = fields;\n const rawToolCalls = initParams.additional_kwargs?.tool_calls;\n const toolCalls = initParams.tool_calls;\n if (!(rawToolCalls == null) &&\n rawToolCalls.length > 0 &&\n (toolCalls === undefined || toolCalls.length === 0)) {\n console.warn([\n \"New LangChain packages are available that more efficiently handle\",\n \"tool calling.\\n\\nPlease upgrade your packages to versions that set\",\n \"message tool calls. e.g., `yarn add @langchain/anthropic`,\",\n \"yarn add @langchain/openai`, etc.\",\n ].join(\" \"));\n }\n try {\n if (!(rawToolCalls == null) && toolCalls === undefined) {\n const [toolCalls, invalidToolCalls] = (0, tool_js_1.defaultToolCallParser)(rawToolCalls);\n initParams.tool_calls = toolCalls ?? [];\n initParams.invalid_tool_calls = invalidToolCalls ?? [];\n }\n else {\n initParams.tool_calls = initParams.tool_calls ?? [];\n initParams.invalid_tool_calls = initParams.invalid_tool_calls ?? [];\n }\n }\n catch (e) {\n // Do nothing if parsing fails\n initParams.tool_calls = [];\n initParams.invalid_tool_calls = [];\n }\n }\n // Sadly, TypeScript only allows super() calls at root if the class has\n // properties with initializers, so we have to check types twice.\n super(initParams);\n // These are typed as optional to avoid breaking changes and allow for casting\n // from BaseMessage.\n Object.defineProperty(this, \"tool_calls\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: []\n });\n Object.defineProperty(this, \"invalid_tool_calls\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: []\n });\n /**\n * If provided, token usage information associated with the message.\n */\n Object.defineProperty(this, \"usage_metadata\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n if (typeof initParams !== \"string\") {\n this.tool_calls = initParams.tool_calls ?? this.tool_calls;\n this.invalid_tool_calls =\n initParams.invalid_tool_calls ?? this.invalid_tool_calls;\n }\n this.usage_metadata = initParams.usage_metadata;\n }\n static lc_name() {\n return \"AIMessage\";\n }\n _getType() {\n return \"ai\";\n }\n get _printableFields() {\n return {\n ...super._printableFields,\n tool_calls: this.tool_calls,\n invalid_tool_calls: this.invalid_tool_calls,\n usage_metadata: this.usage_metadata,\n };\n }\n}\nexports.AIMessage = AIMessage;\nfunction isAIMessage(x) {\n return x._getType() === \"ai\";\n}\nfunction isAIMessageChunk(x) {\n return x._getType() === \"ai\";\n}\n/**\n * Represents a chunk of an AI message, which can be concatenated with\n * other AI message chunks.\n */\nclass AIMessageChunk extends base_js_1.BaseMessageChunk {\n constructor(fields) {\n let initParams;\n if (typeof fields === \"string\") {\n initParams = {\n content: fields,\n tool_calls: [],\n invalid_tool_calls: [],\n tool_call_chunks: [],\n };\n }\n else if (fields.tool_call_chunks === undefined ||\n fields.tool_call_chunks.length === 0) {\n initParams = {\n ...fields,\n tool_calls: fields.tool_calls ?? [],\n invalid_tool_calls: [],\n tool_call_chunks: [],\n usage_metadata: fields.usage_metadata !== undefined\n ? fields.usage_metadata\n : undefined,\n };\n }\n else {\n const toolCallChunks = fields.tool_call_chunks ?? [];\n const groupedToolCallChunks = toolCallChunks.reduce((acc, chunk) => {\n const matchedChunkIndex = acc.findIndex(([match]) => {\n // If chunk has an id and index, match if both are present\n if (\"id\" in chunk &&\n chunk.id &&\n \"index\" in chunk &&\n chunk.index !== undefined) {\n return chunk.id === match.id && chunk.index === match.index;\n }\n // If chunk has an id, we match on id\n if (\"id\" in chunk && chunk.id) {\n return chunk.id === match.id;\n }\n // If chunk has an index, we match on index\n if (\"index\" in chunk && chunk.index !== undefined) {\n return chunk.index === match.index;\n }\n return false;\n });\n if (matchedChunkIndex !== -1) {\n acc[matchedChunkIndex].push(chunk);\n }\n else {\n acc.push([chunk]);\n }\n return acc;\n }, []);\n const toolCalls = [];\n const invalidToolCalls = [];\n for (const chunks of groupedToolCallChunks) {\n let parsedArgs = {};\n const name = chunks[0]?.name ?? \"\";\n const joinedArgs = chunks.map((c) => c.args || \"\").join(\"\");\n const argsStr = joinedArgs.length ? joinedArgs : \"{}\";\n const id = chunks[0]?.id;\n try {\n parsedArgs = (0, json_js_1.parsePartialJson)(argsStr);\n if (!id ||\n parsedArgs === null ||\n typeof parsedArgs !== \"object\" ||\n Array.isArray(parsedArgs)) {\n throw new Error(\"Malformed tool call chunk args.\");\n }\n toolCalls.push({\n name,\n args: parsedArgs,\n id,\n type: \"tool_call\",\n });\n }\n catch (e) {\n invalidToolCalls.push({\n name,\n args: argsStr,\n id,\n error: \"Malformed args.\",\n type: \"invalid_tool_call\",\n });\n }\n }\n initParams = {\n ...fields,\n tool_calls: toolCalls,\n invalid_tool_calls: invalidToolCalls,\n usage_metadata: fields.usage_metadata !== undefined\n ? fields.usage_metadata\n : undefined,\n };\n }\n // Sadly, TypeScript only allows super() calls at root if the class has\n // properties with initializers, so we have to check types twice.\n super(initParams);\n // Must redeclare tool call fields since there is no multiple inheritance in JS.\n // These are typed as optional to avoid breaking changes and allow for casting\n // from BaseMessage.\n Object.defineProperty(this, \"tool_calls\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: []\n });\n Object.defineProperty(this, \"invalid_tool_calls\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: []\n });\n Object.defineProperty(this, \"tool_call_chunks\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: []\n });\n /**\n * If provided, token usage information associated with the message.\n */\n Object.defineProperty(this, \"usage_metadata\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.tool_call_chunks =\n initParams.tool_call_chunks ?? this.tool_call_chunks;\n this.tool_calls = initParams.tool_calls ?? this.tool_calls;\n this.invalid_tool_calls =\n initParams.invalid_tool_calls ?? this.invalid_tool_calls;\n this.usage_metadata = initParams.usage_metadata;\n }\n get lc_aliases() {\n // exclude snake case conversion to pascal case\n return {\n ...super.lc_aliases,\n tool_calls: \"tool_calls\",\n invalid_tool_calls: \"invalid_tool_calls\",\n tool_call_chunks: \"tool_call_chunks\",\n };\n }\n static lc_name() {\n return \"AIMessageChunk\";\n }\n _getType() {\n return \"ai\";\n }\n get _printableFields() {\n return {\n ...super._printableFields,\n tool_calls: this.tool_calls,\n tool_call_chunks: this.tool_call_chunks,\n invalid_tool_calls: this.invalid_tool_calls,\n usage_metadata: this.usage_metadata,\n };\n }\n concat(chunk) {\n const combinedFields = {\n content: (0, base_js_1.mergeContent)(this.content, chunk.content),\n additional_kwargs: (0, base_js_1._mergeDicts)(this.additional_kwargs, chunk.additional_kwargs),\n response_metadata: (0, base_js_1._mergeDicts)(this.response_metadata, chunk.response_metadata),\n tool_call_chunks: [],\n id: this.id ?? chunk.id,\n };\n if (this.tool_call_chunks !== undefined ||\n chunk.tool_call_chunks !== undefined) {\n const rawToolCalls = (0, base_js_1._mergeLists)(this.tool_call_chunks, chunk.tool_call_chunks);\n if (rawToolCalls !== undefined && rawToolCalls.length > 0) {\n combinedFields.tool_call_chunks = rawToolCalls;\n }\n }\n if (this.usage_metadata !== undefined ||\n chunk.usage_metadata !== undefined) {\n const inputTokenDetails = {\n ...((this.usage_metadata?.input_token_details?.audio !== undefined ||\n chunk.usage_metadata?.input_token_details?.audio !== undefined) && {\n audio: (this.usage_metadata?.input_token_details?.audio ?? 0) +\n (chunk.usage_metadata?.input_token_details?.audio ?? 0),\n }),\n ...((this.usage_metadata?.input_token_details?.cache_read !==\n undefined ||\n chunk.usage_metadata?.input_token_details?.cache_read !==\n undefined) && {\n cache_read: (this.usage_metadata?.input_token_details?.cache_read ?? 0) +\n (chunk.usage_metadata?.input_token_details?.cache_read ?? 0),\n }),\n ...((this.usage_metadata?.input_token_details?.cache_creation !==\n undefined ||\n chunk.usage_metadata?.input_token_details?.cache_creation !==\n undefined) && {\n cache_creation: (this.usage_metadata?.input_token_details?.cache_creation ?? 0) +\n (chunk.usage_metadata?.input_token_details?.cache_creation ?? 0),\n }),\n };\n const outputTokenDetails = {\n ...((this.usage_metadata?.output_token_details?.audio !== undefined ||\n chunk.usage_metadata?.output_token_details?.audio !== undefined) && {\n audio: (this.usage_metadata?.output_token_details?.audio ?? 0) +\n (chunk.usage_metadata?.output_token_details?.audio ?? 0),\n }),\n ...((this.usage_metadata?.output_token_details?.reasoning !==\n undefined ||\n chunk.usage_metadata?.output_token_details?.reasoning !==\n undefined) && {\n reasoning: (this.usage_metadata?.output_token_details?.reasoning ?? 0) +\n (chunk.usage_metadata?.output_token_details?.reasoning ?? 0),\n }),\n };\n const left = this.usage_metadata ?? {\n input_tokens: 0,\n output_tokens: 0,\n total_tokens: 0,\n };\n const right = chunk.usage_metadata ?? {\n input_tokens: 0,\n output_tokens: 0,\n total_tokens: 0,\n };\n const usage_metadata = {\n input_tokens: left.input_tokens + right.input_tokens,\n output_tokens: left.output_tokens + right.output_tokens,\n total_tokens: left.total_tokens + right.total_tokens,\n // Do not include `input_token_details` / `output_token_details` keys in combined fields\n // unless their values are defined.\n ...(Object.keys(inputTokenDetails).length > 0 && {\n input_token_details: inputTokenDetails,\n }),\n ...(Object.keys(outputTokenDetails).length > 0 && {\n output_token_details: outputTokenDetails,\n }),\n };\n combinedFields.usage_metadata = usage_metadata;\n }\n return new AIMessageChunk(combinedFields);\n }\n}\nexports.AIMessageChunk = AIMessageChunk;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ChatMessageChunk = exports.ChatMessage = void 0;\nexports.isChatMessage = isChatMessage;\nexports.isChatMessageChunk = isChatMessageChunk;\nconst base_js_1 = require(\"./base.cjs\");\n/**\n * Represents a chat message in a conversation.\n */\nclass ChatMessage extends base_js_1.BaseMessage {\n static lc_name() {\n return \"ChatMessage\";\n }\n static _chatMessageClass() {\n return ChatMessage;\n }\n constructor(fields, role) {\n if (typeof fields === \"string\") {\n // eslint-disable-next-line no-param-reassign, @typescript-eslint/no-non-null-assertion\n fields = { content: fields, role: role };\n }\n super(fields);\n Object.defineProperty(this, \"role\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.role = fields.role;\n }\n _getType() {\n return \"generic\";\n }\n static isInstance(message) {\n return message._getType() === \"generic\";\n }\n get _printableFields() {\n return {\n ...super._printableFields,\n role: this.role,\n };\n }\n}\nexports.ChatMessage = ChatMessage;\n/**\n * Represents a chunk of a chat message, which can be concatenated with\n * other chat message chunks.\n */\nclass ChatMessageChunk extends base_js_1.BaseMessageChunk {\n static lc_name() {\n return \"ChatMessageChunk\";\n }\n constructor(fields, role) {\n if (typeof fields === \"string\") {\n // eslint-disable-next-line no-param-reassign, @typescript-eslint/no-non-null-assertion\n fields = { content: fields, role: role };\n }\n super(fields);\n Object.defineProperty(this, \"role\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.role = fields.role;\n }\n _getType() {\n return \"generic\";\n }\n concat(chunk) {\n return new ChatMessageChunk({\n content: (0, base_js_1.mergeContent)(this.content, chunk.content),\n additional_kwargs: (0, base_js_1._mergeDicts)(this.additional_kwargs, chunk.additional_kwargs),\n response_metadata: (0, base_js_1._mergeDicts)(this.response_metadata, chunk.response_metadata),\n role: this.role,\n id: this.id ?? chunk.id,\n });\n }\n get _printableFields() {\n return {\n ...super._printableFields,\n role: this.role,\n };\n }\n}\nexports.ChatMessageChunk = ChatMessageChunk;\nfunction isChatMessage(x) {\n return x._getType() === \"generic\";\n}\nfunction isChatMessageChunk(x) {\n return x._getType() === \"generic\";\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.FunctionMessageChunk = exports.FunctionMessage = void 0;\nexports.isFunctionMessage = isFunctionMessage;\nexports.isFunctionMessageChunk = isFunctionMessageChunk;\nconst base_js_1 = require(\"./base.cjs\");\n/**\n * Represents a function message in a conversation.\n */\nclass FunctionMessage extends base_js_1.BaseMessage {\n static lc_name() {\n return \"FunctionMessage\";\n }\n constructor(fields, \n /** @deprecated */\n name) {\n if (typeof fields === \"string\") {\n // eslint-disable-next-line no-param-reassign, @typescript-eslint/no-non-null-assertion\n fields = { content: fields, name: name };\n }\n super(fields);\n }\n _getType() {\n return \"function\";\n }\n}\nexports.FunctionMessage = FunctionMessage;\n/**\n * Represents a chunk of a function message, which can be concatenated\n * with other function message chunks.\n */\nclass FunctionMessageChunk extends base_js_1.BaseMessageChunk {\n static lc_name() {\n return \"FunctionMessageChunk\";\n }\n _getType() {\n return \"function\";\n }\n concat(chunk) {\n return new FunctionMessageChunk({\n content: (0, base_js_1.mergeContent)(this.content, chunk.content),\n additional_kwargs: (0, base_js_1._mergeDicts)(this.additional_kwargs, chunk.additional_kwargs),\n response_metadata: (0, base_js_1._mergeDicts)(this.response_metadata, chunk.response_metadata),\n name: this.name ?? \"\",\n id: this.id ?? chunk.id,\n });\n }\n}\nexports.FunctionMessageChunk = FunctionMessageChunk;\nfunction isFunctionMessage(x) {\n return x._getType() === \"function\";\n}\nfunction isFunctionMessageChunk(x) {\n return x._getType() === \"function\";\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.HumanMessageChunk = exports.HumanMessage = void 0;\nexports.isHumanMessage = isHumanMessage;\nexports.isHumanMessageChunk = isHumanMessageChunk;\nconst base_js_1 = require(\"./base.cjs\");\n/**\n * Represents a human message in a conversation.\n */\nclass HumanMessage extends base_js_1.BaseMessage {\n static lc_name() {\n return \"HumanMessage\";\n }\n _getType() {\n return \"human\";\n }\n constructor(fields, \n /** @deprecated */\n kwargs) {\n super(fields, kwargs);\n }\n}\nexports.HumanMessage = HumanMessage;\n/**\n * Represents a chunk of a human message, which can be concatenated with\n * other human message chunks.\n */\nclass HumanMessageChunk extends base_js_1.BaseMessageChunk {\n static lc_name() {\n return \"HumanMessageChunk\";\n }\n _getType() {\n return \"human\";\n }\n constructor(fields, \n /** @deprecated */\n kwargs) {\n super(fields, kwargs);\n }\n concat(chunk) {\n return new HumanMessageChunk({\n content: (0, base_js_1.mergeContent)(this.content, chunk.content),\n additional_kwargs: (0, base_js_1._mergeDicts)(this.additional_kwargs, chunk.additional_kwargs),\n response_metadata: (0, base_js_1._mergeDicts)(this.response_metadata, chunk.response_metadata),\n id: this.id ?? chunk.id,\n });\n }\n}\nexports.HumanMessageChunk = HumanMessageChunk;\nfunction isHumanMessage(x) {\n return x.getType() === \"human\";\n}\nfunction isHumanMessageChunk(x) {\n return x.getType() === \"human\";\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.RemoveMessage = void 0;\nconst base_js_1 = require(\"./base.cjs\");\n/**\n * Message responsible for deleting other messages.\n */\nclass RemoveMessage extends base_js_1.BaseMessage {\n constructor(fields) {\n super({\n ...fields,\n content: \"\",\n });\n /**\n * The ID of the message to remove.\n */\n Object.defineProperty(this, \"id\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.id = fields.id;\n }\n _getType() {\n return \"remove\";\n }\n get _printableFields() {\n return {\n ...super._printableFields,\n id: this.id,\n };\n }\n}\nexports.RemoveMessage = RemoveMessage;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.SystemMessageChunk = exports.SystemMessage = void 0;\nexports.isSystemMessage = isSystemMessage;\nexports.isSystemMessageChunk = isSystemMessageChunk;\nconst base_js_1 = require(\"./base.cjs\");\n/**\n * Represents a system message in a conversation.\n */\nclass SystemMessage extends base_js_1.BaseMessage {\n static lc_name() {\n return \"SystemMessage\";\n }\n _getType() {\n return \"system\";\n }\n constructor(fields, \n /** @deprecated */\n kwargs) {\n super(fields, kwargs);\n }\n}\nexports.SystemMessage = SystemMessage;\n/**\n * Represents a chunk of a system message, which can be concatenated with\n * other system message chunks.\n */\nclass SystemMessageChunk extends base_js_1.BaseMessageChunk {\n static lc_name() {\n return \"SystemMessageChunk\";\n }\n _getType() {\n return \"system\";\n }\n constructor(fields, \n /** @deprecated */\n kwargs) {\n super(fields, kwargs);\n }\n concat(chunk) {\n return new SystemMessageChunk({\n content: (0, base_js_1.mergeContent)(this.content, chunk.content),\n additional_kwargs: (0, base_js_1._mergeDicts)(this.additional_kwargs, chunk.additional_kwargs),\n response_metadata: (0, base_js_1._mergeDicts)(this.response_metadata, chunk.response_metadata),\n id: this.id ?? chunk.id,\n });\n }\n}\nexports.SystemMessageChunk = SystemMessageChunk;\nfunction isSystemMessage(x) {\n return x._getType() === \"system\";\n}\nfunction isSystemMessageChunk(x) {\n return x._getType() === \"system\";\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.coerceMessageLikeToMessage = coerceMessageLikeToMessage;\nexports.getBufferString = getBufferString;\nexports.mapStoredMessageToChatMessage = mapStoredMessageToChatMessage;\nexports.mapStoredMessagesToChatMessages = mapStoredMessagesToChatMessages;\nexports.mapChatMessagesToStoredMessages = mapChatMessagesToStoredMessages;\nexports.convertToChunk = convertToChunk;\nconst index_js_1 = require(\"../errors/index.cjs\");\nconst utils_js_1 = require(\"../tools/utils.cjs\");\nconst ai_js_1 = require(\"./ai.cjs\");\nconst base_js_1 = require(\"./base.cjs\");\nconst chat_js_1 = require(\"./chat.cjs\");\nconst function_js_1 = require(\"./function.cjs\");\nconst human_js_1 = require(\"./human.cjs\");\nconst modifier_js_1 = require(\"./modifier.cjs\");\nconst system_js_1 = require(\"./system.cjs\");\nconst tool_js_1 = require(\"./tool.cjs\");\nfunction _coerceToolCall(toolCall) {\n if ((0, utils_js_1._isToolCall)(toolCall)) {\n return toolCall;\n }\n else if (typeof toolCall.id === \"string\" &&\n toolCall.type === \"function\" &&\n typeof toolCall.function === \"object\" &&\n toolCall.function !== null &&\n \"arguments\" in toolCall.function &&\n typeof toolCall.function.arguments === \"string\" &&\n \"name\" in toolCall.function &&\n typeof toolCall.function.name === \"string\") {\n // Handle OpenAI tool call format\n return {\n id: toolCall.id,\n args: JSON.parse(toolCall.function.arguments),\n name: toolCall.function.name,\n type: \"tool_call\",\n };\n }\n else {\n // TODO: Throw an error?\n return toolCall;\n }\n}\nfunction isSerializedConstructor(x) {\n return (typeof x === \"object\" &&\n x != null &&\n x.lc === 1 &&\n Array.isArray(x.id) &&\n x.kwargs != null &&\n typeof x.kwargs === \"object\");\n}\nfunction _constructMessageFromParams(params) {\n let type;\n let rest;\n // Support serialized messages\n if (isSerializedConstructor(params)) {\n const className = params.id.at(-1);\n if (className === \"HumanMessage\" || className === \"HumanMessageChunk\") {\n type = \"user\";\n }\n else if (className === \"AIMessage\" || className === \"AIMessageChunk\") {\n type = \"assistant\";\n }\n else if (className === \"SystemMessage\" ||\n className === \"SystemMessageChunk\") {\n type = \"system\";\n }\n else if (className === \"FunctionMessage\" ||\n className === \"FunctionMessageChunk\") {\n type = \"function\";\n }\n else if (className === \"ToolMessage\" ||\n className === \"ToolMessageChunk\") {\n type = \"tool\";\n }\n else {\n type = \"unknown\";\n }\n rest = params.kwargs;\n }\n else {\n const { type: extractedType, ...otherParams } = params;\n type = extractedType;\n rest = otherParams;\n }\n if (type === \"human\" || type === \"user\") {\n return new human_js_1.HumanMessage(rest);\n }\n else if (type === \"ai\" || type === \"assistant\") {\n const { tool_calls: rawToolCalls, ...other } = rest;\n if (!Array.isArray(rawToolCalls)) {\n return new ai_js_1.AIMessage(rest);\n }\n const tool_calls = rawToolCalls.map(_coerceToolCall);\n return new ai_js_1.AIMessage({ ...other, tool_calls });\n }\n else if (type === \"system\") {\n return new system_js_1.SystemMessage(rest);\n }\n else if (type === \"developer\") {\n return new system_js_1.SystemMessage({\n ...rest,\n additional_kwargs: {\n ...rest.additional_kwargs,\n __openai_role__: \"developer\",\n },\n });\n }\n else if (type === \"tool\" && \"tool_call_id\" in rest) {\n return new tool_js_1.ToolMessage({\n ...rest,\n content: rest.content,\n tool_call_id: rest.tool_call_id,\n name: rest.name,\n });\n }\n else if (type === \"remove\" && \"id\" in rest && typeof rest.id === \"string\") {\n return new modifier_js_1.RemoveMessage({ ...rest, id: rest.id });\n }\n else {\n const error = (0, index_js_1.addLangChainErrorFields)(new Error(`Unable to coerce message from array: only human, AI, system, developer, or tool message coercion is currently supported.\\n\\nReceived: ${JSON.stringify(params, null, 2)}`), \"MESSAGE_COERCION_FAILURE\");\n throw error;\n }\n}\nfunction coerceMessageLikeToMessage(messageLike) {\n if (typeof messageLike === \"string\") {\n return new human_js_1.HumanMessage(messageLike);\n }\n else if ((0, base_js_1.isBaseMessage)(messageLike)) {\n return messageLike;\n }\n if (Array.isArray(messageLike)) {\n const [type, content] = messageLike;\n return _constructMessageFromParams({ type, content });\n }\n else if ((0, base_js_1._isMessageFieldWithRole)(messageLike)) {\n const { role: type, ...rest } = messageLike;\n return _constructMessageFromParams({ ...rest, type });\n }\n else {\n return _constructMessageFromParams(messageLike);\n }\n}\n/**\n * This function is used by memory classes to get a string representation\n * of the chat message history, based on the message content and role.\n */\nfunction getBufferString(messages, humanPrefix = \"Human\", aiPrefix = \"AI\") {\n const string_messages = [];\n for (const m of messages) {\n let role;\n if (m._getType() === \"human\") {\n role = humanPrefix;\n }\n else if (m._getType() === \"ai\") {\n role = aiPrefix;\n }\n else if (m._getType() === \"system\") {\n role = \"System\";\n }\n else if (m._getType() === \"function\") {\n role = \"Function\";\n }\n else if (m._getType() === \"tool\") {\n role = \"Tool\";\n }\n else if (m._getType() === \"generic\") {\n role = m.role;\n }\n else {\n throw new Error(`Got unsupported message type: ${m._getType()}`);\n }\n const nameStr = m.name ? `${m.name}, ` : \"\";\n const readableContent = typeof m.content === \"string\"\n ? m.content\n : JSON.stringify(m.content, null, 2);\n string_messages.push(`${role}: ${nameStr}${readableContent}`);\n }\n return string_messages.join(\"\\n\");\n}\n/**\n * Maps messages from an older format (V1) to the current `StoredMessage`\n * format. If the message is already in the `StoredMessage` format, it is\n * returned as is. Otherwise, it transforms the V1 message into a\n * `StoredMessage`. This function is important for maintaining\n * compatibility with older message formats.\n */\nfunction mapV1MessageToStoredMessage(message) {\n // TODO: Remove this mapper when we deprecate the old message format.\n if (message.data !== undefined) {\n return message;\n }\n else {\n const v1Message = message;\n return {\n type: v1Message.type,\n data: {\n content: v1Message.text,\n role: v1Message.role,\n name: undefined,\n tool_call_id: undefined,\n },\n };\n }\n}\nfunction mapStoredMessageToChatMessage(message) {\n const storedMessage = mapV1MessageToStoredMessage(message);\n switch (storedMessage.type) {\n case \"human\":\n return new human_js_1.HumanMessage(storedMessage.data);\n case \"ai\":\n return new ai_js_1.AIMessage(storedMessage.data);\n case \"system\":\n return new system_js_1.SystemMessage(storedMessage.data);\n case \"function\":\n if (storedMessage.data.name === undefined) {\n throw new Error(\"Name must be defined for function messages\");\n }\n return new function_js_1.FunctionMessage(storedMessage.data);\n case \"tool\":\n if (storedMessage.data.tool_call_id === undefined) {\n throw new Error(\"Tool call ID must be defined for tool messages\");\n }\n return new tool_js_1.ToolMessage(storedMessage.data);\n case \"generic\": {\n if (storedMessage.data.role === undefined) {\n throw new Error(\"Role must be defined for chat messages\");\n }\n return new chat_js_1.ChatMessage(storedMessage.data);\n }\n default:\n throw new Error(`Got unexpected type: ${storedMessage.type}`);\n }\n}\n/**\n * Transforms an array of `StoredMessage` instances into an array of\n * `BaseMessage` instances. It uses the `mapV1MessageToStoredMessage`\n * function to ensure all messages are in the `StoredMessage` format, then\n * creates new instances of the appropriate `BaseMessage` subclass based\n * on the type of each message. This function is used to prepare stored\n * messages for use in a chat context.\n */\nfunction mapStoredMessagesToChatMessages(messages) {\n return messages.map(mapStoredMessageToChatMessage);\n}\n/**\n * Transforms an array of `BaseMessage` instances into an array of\n * `StoredMessage` instances. It does this by calling the `toDict` method\n * on each `BaseMessage`, which returns a `StoredMessage`. This function\n * is used to prepare chat messages for storage.\n */\nfunction mapChatMessagesToStoredMessages(messages) {\n return messages.map((message) => message.toDict());\n}\nfunction convertToChunk(message) {\n const type = message._getType();\n if (type === \"human\") {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n return new human_js_1.HumanMessageChunk({ ...message });\n }\n else if (type === \"ai\") {\n let aiChunkFields = {\n ...message,\n };\n if (\"tool_calls\" in aiChunkFields) {\n aiChunkFields = {\n ...aiChunkFields,\n tool_call_chunks: aiChunkFields.tool_calls?.map((tc) => ({\n ...tc,\n type: \"tool_call_chunk\",\n index: undefined,\n args: JSON.stringify(tc.args),\n })),\n };\n }\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n return new ai_js_1.AIMessageChunk({ ...aiChunkFields });\n }\n else if (type === \"system\") {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n return new system_js_1.SystemMessageChunk({ ...message });\n }\n else if (type === \"function\") {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n return new function_js_1.FunctionMessageChunk({ ...message });\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n }\n else if (chat_js_1.ChatMessage.isInstance(message)) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n return new chat_js_1.ChatMessageChunk({ ...message });\n }\n else {\n throw new Error(\"Unknown message type.\");\n }\n}\n","module.exports = require('./dist/index.cjs');","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ROOT = exports.AsyncLocalStorageProviderSingleton = void 0;\nexports.getCurrentRunTree = getCurrentRunTree;\nexports.withRunTree = withRunTree;\nexports.isTraceableFunction = isTraceableFunction;\nclass MockAsyncLocalStorage {\n getStore() {\n return undefined;\n }\n run(_, callback) {\n return callback();\n }\n}\nconst TRACING_ALS_KEY = Symbol.for(\"ls:tracing_async_local_storage\");\nconst mockAsyncLocalStorage = new MockAsyncLocalStorage();\nclass AsyncLocalStorageProvider {\n getInstance() {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return globalThis[TRACING_ALS_KEY] ?? mockAsyncLocalStorage;\n }\n initializeGlobalInstance(instance) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (globalThis[TRACING_ALS_KEY] === undefined) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n globalThis[TRACING_ALS_KEY] = instance;\n }\n }\n}\nexports.AsyncLocalStorageProviderSingleton = new AsyncLocalStorageProvider();\nfunction getCurrentRunTree(permitAbsentRunTree = false) {\n const runTree = exports.AsyncLocalStorageProviderSingleton.getInstance().getStore();\n if (!permitAbsentRunTree && runTree === undefined) {\n throw new Error(\"Could not get the current run tree.\\n\\nPlease make sure you are calling this method within a traceable function and that tracing is enabled.\");\n }\n return runTree;\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction withRunTree(runTree, fn) {\n const storage = exports.AsyncLocalStorageProviderSingleton.getInstance();\n return new Promise((resolve, reject) => {\n storage.run(runTree, () => void Promise.resolve(fn()).then(resolve).catch(reject));\n });\n}\nexports.ROOT = Symbol.for(\"langsmith:traceable:root\");\nfunction isTraceableFunction(x\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\n) {\n return typeof x === \"function\" && \"langsmith:traceable\" in x;\n}\n","module.exports = require('../dist/singletons/traceable.cjs');","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.setDefaultLangChainClientSingleton = exports.getDefaultLangChainClientSingleton = void 0;\nconst langsmith_1 = require(\"langsmith\");\nconst env_js_1 = require(\"../utils/env.cjs\");\nlet client;\nconst getDefaultLangChainClientSingleton = () => {\n if (client === undefined) {\n const clientParams = (0, env_js_1.getEnvironmentVariable)(\"LANGCHAIN_CALLBACKS_BACKGROUND\") === \"false\"\n ? {\n // LangSmith has its own backgrounding system\n blockOnRootRunFinalization: true,\n }\n : {};\n client = new langsmith_1.Client(clientParams);\n }\n return client;\n};\nexports.getDefaultLangChainClientSingleton = getDefaultLangChainClientSingleton;\nconst setDefaultLangChainClientSingleton = (newClient) => {\n client = newClient;\n};\nexports.setDefaultLangChainClientSingleton = setDefaultLangChainClientSingleton;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.LangChainTracer = void 0;\nconst langsmith_1 = require(\"langsmith\");\nconst run_trees_1 = require(\"langsmith/run_trees\");\nconst traceable_1 = require(\"langsmith/singletons/traceable\");\nconst base_js_1 = require(\"./base.cjs\");\nconst tracer_js_1 = require(\"../singletons/tracer.cjs\");\nclass LangChainTracer extends base_js_1.BaseTracer {\n constructor(fields = {}) {\n super(fields);\n Object.defineProperty(this, \"name\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: \"langchain_tracer\"\n });\n Object.defineProperty(this, \"projectName\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"exampleId\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"client\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"replicas\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"usesRunTreeMap\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: true\n });\n const { exampleId, projectName, client, replicas } = fields;\n this.projectName = projectName ?? (0, langsmith_1.getDefaultProjectName)();\n this.replicas = replicas;\n this.exampleId = exampleId;\n this.client = client ?? (0, tracer_js_1.getDefaultLangChainClientSingleton)();\n const traceableTree = LangChainTracer.getTraceableRunTree();\n if (traceableTree) {\n this.updateFromRunTree(traceableTree);\n }\n }\n async persistRun(_run) { }\n async onRunCreate(run) {\n const runTree = this.getRunTreeWithTracingConfig(run.id);\n await runTree?.postRun();\n }\n async onRunUpdate(run) {\n const runTree = this.getRunTreeWithTracingConfig(run.id);\n await runTree?.patchRun();\n }\n getRun(id) {\n return this.runTreeMap.get(id);\n }\n updateFromRunTree(runTree) {\n this.runTreeMap.set(runTree.id, runTree);\n let rootRun = runTree;\n const visited = new Set();\n while (rootRun.parent_run) {\n if (visited.has(rootRun.id))\n break;\n visited.add(rootRun.id);\n if (!rootRun.parent_run)\n break;\n rootRun = rootRun.parent_run;\n }\n visited.clear();\n const queue = [rootRun];\n while (queue.length > 0) {\n const current = queue.shift();\n if (!current || visited.has(current.id))\n continue;\n visited.add(current.id);\n this.runTreeMap.set(current.id, current);\n if (current.child_runs) {\n queue.push(...current.child_runs);\n }\n }\n this.client = runTree.client ?? this.client;\n this.replicas = runTree.replicas ?? this.replicas;\n this.projectName = runTree.project_name ?? this.projectName;\n this.exampleId = runTree.reference_example_id ?? this.exampleId;\n }\n getRunTreeWithTracingConfig(id) {\n const runTree = this.runTreeMap.get(id);\n if (!runTree)\n return undefined;\n return new run_trees_1.RunTree({\n ...runTree,\n client: this.client,\n project_name: this.projectName,\n replicas: this.replicas,\n reference_example_id: this.exampleId,\n tracingEnabled: true,\n });\n }\n static getTraceableRunTree() {\n try {\n return (\n // The type cast here provides forward compatibility. Old versions of LangSmith will just\n // ignore the permitAbsentRunTree arg.\n traceable_1.getCurrentRunTree(true));\n }\n catch {\n return undefined;\n }\n }\n}\nexports.LangChainTracer = LangChainTracer;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getGlobalAsyncLocalStorageInstance = exports.setGlobalAsyncLocalStorageInstance = exports._CONTEXT_VARIABLES_KEY = exports.TRACING_ALS_KEY = void 0;\nexports.TRACING_ALS_KEY = Symbol.for(\"ls:tracing_async_local_storage\");\nexports._CONTEXT_VARIABLES_KEY = Symbol.for(\"lc:context_variables\");\nconst setGlobalAsyncLocalStorageInstance = (instance) => {\n globalThis[exports.TRACING_ALS_KEY] = instance;\n};\nexports.setGlobalAsyncLocalStorageInstance = setGlobalAsyncLocalStorageInstance;\nconst getGlobalAsyncLocalStorageInstance = () => {\n return globalThis[exports.TRACING_ALS_KEY];\n};\nexports.getGlobalAsyncLocalStorageInstance = getGlobalAsyncLocalStorageInstance;\n","\"use strict\";\n/* eslint-disable @typescript-eslint/no-explicit-any */\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getQueue = getQueue;\nexports.consumeCallback = consumeCallback;\nexports.awaitAllCallbacks = awaitAllCallbacks;\nconst p_queue_1 = __importDefault(require(\"p-queue\"));\nconst globals_js_1 = require(\"./async_local_storage/globals.cjs\");\nconst tracer_js_1 = require(\"./tracer.cjs\");\nlet queue;\n/**\n * Creates a queue using the p-queue library. The queue is configured to\n * auto-start and has a concurrency of 1, meaning it will process tasks\n * one at a time.\n */\nfunction createQueue() {\n const PQueue = \"default\" in p_queue_1.default ? p_queue_1.default.default : p_queue_1.default;\n return new PQueue({\n autoStart: true,\n concurrency: 1,\n });\n}\nfunction getQueue() {\n if (typeof queue === \"undefined\") {\n queue = createQueue();\n }\n return queue;\n}\n/**\n * Consume a promise, either adding it to the queue or waiting for it to resolve\n * @param promiseFn Promise to consume\n * @param wait Whether to wait for the promise to resolve or resolve immediately\n */\nasync function consumeCallback(promiseFn, wait) {\n if (wait === true) {\n // Clear config since callbacks are not part of the root run\n // Avoid using global singleton due to circuluar dependency issues\n const asyncLocalStorageInstance = (0, globals_js_1.getGlobalAsyncLocalStorageInstance)();\n if (asyncLocalStorageInstance !== undefined) {\n await asyncLocalStorageInstance.run(undefined, async () => promiseFn());\n }\n else {\n await promiseFn();\n }\n }\n else {\n queue = getQueue();\n void queue.add(async () => {\n const asyncLocalStorageInstance = (0, globals_js_1.getGlobalAsyncLocalStorageInstance)();\n if (asyncLocalStorageInstance !== undefined) {\n await asyncLocalStorageInstance.run(undefined, async () => promiseFn());\n }\n else {\n await promiseFn();\n }\n });\n }\n}\n/**\n * Waits for all promises in the queue to resolve. If the queue is\n * undefined, it immediately resolves a promise.\n */\nasync function awaitAllCallbacks() {\n const defaultClient = (0, tracer_js_1.getDefaultLangChainClientSingleton)();\n await Promise.allSettled([\n typeof queue !== \"undefined\" ? queue.onIdle() : Promise.resolve(),\n defaultClient.awaitPendingTraceBatches(),\n ]);\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.consumeCallback = exports.awaitAllCallbacks = void 0;\nconst callbacks_js_1 = require(\"../singletons/callbacks.cjs\");\nObject.defineProperty(exports, \"awaitAllCallbacks\", { enumerable: true, get: function () { return callbacks_js_1.awaitAllCallbacks; } });\nObject.defineProperty(exports, \"consumeCallback\", { enumerable: true, get: function () { return callbacks_js_1.consumeCallback; } });\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isTracingEnabled = void 0;\nconst env_js_1 = require(\"./env.cjs\");\nconst isTracingEnabled = (tracingEnabled) => {\n if (tracingEnabled !== undefined) {\n return tracingEnabled;\n }\n const envVars = [\n \"LANGSMITH_TRACING_V2\",\n \"LANGCHAIN_TRACING_V2\",\n \"LANGSMITH_TRACING\",\n \"LANGCHAIN_TRACING\",\n ];\n return !!envVars.find((envVar) => (0, env_js_1.getEnvironmentVariable)(envVar) === \"true\");\n};\nexports.isTracingEnabled = isTracingEnabled;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.registerConfigureHook = exports._getConfigureHooks = void 0;\nexports.setContextVariable = setContextVariable;\nexports.getContextVariable = getContextVariable;\nconst run_trees_1 = require(\"langsmith/run_trees\");\nconst globals_js_1 = require(\"./globals.cjs\");\n/**\n * Set a context variable. Context variables are scoped to any\n * child runnables called by the current runnable, or globally if set outside\n * of any runnable.\n *\n * @remarks\n * This function is only supported in environments that support AsyncLocalStorage,\n * including Node.js, Deno, and Cloudflare Workers.\n *\n * @example\n * ```ts\n * import { RunnableLambda } from \"@langchain/core/runnables\";\n * import {\n * getContextVariable,\n * setContextVariable\n * } from \"@langchain/core/context\";\n *\n * const nested = RunnableLambda.from(() => {\n * // \"bar\" because it was set by a parent\n * console.log(getContextVariable(\"foo\"));\n *\n * // Override to \"baz\", but only for child runnables\n * setContextVariable(\"foo\", \"baz\");\n *\n * // Now \"baz\", but only for child runnables\n * return getContextVariable(\"foo\");\n * });\n *\n * const runnable = RunnableLambda.from(async () => {\n * // Set a context variable named \"foo\"\n * setContextVariable(\"foo\", \"bar\");\n *\n * const res = await nested.invoke({});\n *\n * // Still \"bar\" since child changes do not affect parents\n * console.log(getContextVariable(\"foo\"));\n *\n * return res;\n * });\n *\n * // undefined, because context variable has not been set yet\n * console.log(getContextVariable(\"foo\"));\n *\n * // Final return value is \"baz\"\n * const result = await runnable.invoke({});\n * ```\n *\n * @param name The name of the context variable.\n * @param value The value to set.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction setContextVariable(name, value) {\n // Avoid using global singleton due to circuluar dependency issues\n const asyncLocalStorageInstance = (0, globals_js_1.getGlobalAsyncLocalStorageInstance)();\n if (asyncLocalStorageInstance === undefined) {\n throw new Error(`Internal error: Global shared async local storage instance has not been initialized.`);\n }\n const runTree = asyncLocalStorageInstance.getStore();\n const contextVars = { ...runTree?.[globals_js_1._CONTEXT_VARIABLES_KEY] };\n contextVars[name] = value;\n let newValue = {};\n if ((0, run_trees_1.isRunTree)(runTree)) {\n newValue = new run_trees_1.RunTree(runTree);\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n newValue[globals_js_1._CONTEXT_VARIABLES_KEY] = contextVars;\n asyncLocalStorageInstance.enterWith(newValue);\n}\n/**\n * Get the value of a previously set context variable. Context variables\n * are scoped to any child runnables called by the current runnable,\n * or globally if set outside of any runnable.\n *\n * @remarks\n * This function is only supported in environments that support AsyncLocalStorage,\n * including Node.js, Deno, and Cloudflare Workers.\n *\n * @example\n * ```ts\n * import { RunnableLambda } from \"@langchain/core/runnables\";\n * import {\n * getContextVariable,\n * setContextVariable\n * } from \"@langchain/core/context\";\n *\n * const nested = RunnableLambda.from(() => {\n * // \"bar\" because it was set by a parent\n * console.log(getContextVariable(\"foo\"));\n *\n * // Override to \"baz\", but only for child runnables\n * setContextVariable(\"foo\", \"baz\");\n *\n * // Now \"baz\", but only for child runnables\n * return getContextVariable(\"foo\");\n * });\n *\n * const runnable = RunnableLambda.from(async () => {\n * // Set a context variable named \"foo\"\n * setContextVariable(\"foo\", \"bar\");\n *\n * const res = await nested.invoke({});\n *\n * // Still \"bar\" since child changes do not affect parents\n * console.log(getContextVariable(\"foo\"));\n *\n * return res;\n * });\n *\n * // undefined, because context variable has not been set yet\n * console.log(getContextVariable(\"foo\"));\n *\n * // Final return value is \"baz\"\n * const result = await runnable.invoke({});\n * ```\n *\n * @param name The name of the context variable.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getContextVariable(name) {\n // Avoid using global singleton due to circuluar dependency issues\n const asyncLocalStorageInstance = (0, globals_js_1.getGlobalAsyncLocalStorageInstance)();\n if (asyncLocalStorageInstance === undefined) {\n return undefined;\n }\n const runTree = asyncLocalStorageInstance.getStore();\n return runTree?.[globals_js_1._CONTEXT_VARIABLES_KEY]?.[name];\n}\nconst LC_CONFIGURE_HOOKS_KEY = Symbol(\"lc:configure_hooks\");\nconst _getConfigureHooks = () => getContextVariable(LC_CONFIGURE_HOOKS_KEY) || [];\nexports._getConfigureHooks = _getConfigureHooks;\n/**\n * Register a callback configure hook to automatically add callback handlers to all runs.\n *\n * There are two ways to use this:\n *\n * 1. Using a context variable:\n * - Set `contextVar` to specify the variable name\n * - Use `setContextVariable()` to store your handler instance\n *\n * 2. Using an environment variable:\n * - Set both `envVar` and `handlerClass`\n * - The handler will be instantiated when the env var is set to \"true\".\n *\n * @example\n * ```typescript\n * // Method 1: Using context variable\n * import {\n * registerConfigureHook,\n * setContextVariable\n * } from \"@langchain/core/context\";\n *\n * const tracer = new MyCallbackHandler();\n * registerConfigureHook({\n * contextVar: \"my_tracer\",\n * });\n * setContextVariable(\"my_tracer\", tracer);\n *\n * // ...run code here\n *\n * // Method 2: Using environment variable\n * registerConfigureHook({\n * handlerClass: MyCallbackHandler,\n * envVar: \"MY_TRACER_ENABLED\",\n * });\n * process.env.MY_TRACER_ENABLED = \"true\";\n *\n * // ...run code here\n * ```\n *\n * @param config Configuration object for the hook\n * @param config.contextVar Name of the context variable containing the handler instance\n * @param config.inheritable Whether child runs should inherit this handler\n * @param config.handlerClass Optional callback handler class (required if using envVar)\n * @param config.envVar Optional environment variable name to control handler activation\n */\nconst registerConfigureHook = (config) => {\n if (config.envVar && !config.handlerClass) {\n throw new Error(\"If envVar is set, handlerClass must also be set to a non-None value.\");\n }\n setContextVariable(LC_CONFIGURE_HOOKS_KEY, [...(0, exports._getConfigureHooks)(), config]);\n};\nexports.registerConfigureHook = registerConfigureHook;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.TraceGroup = exports.CallbackManager = exports.CallbackManagerForToolRun = exports.CallbackManagerForChainRun = exports.CallbackManagerForLLMRun = exports.CallbackManagerForRetrieverRun = exports.BaseRunManager = exports.BaseCallbackManager = void 0;\nexports.parseCallbackConfigArg = parseCallbackConfigArg;\nexports.ensureHandler = ensureHandler;\nexports.traceAsGroup = traceAsGroup;\nconst uuid_1 = require(\"uuid\");\nconst base_js_1 = require(\"./base.cjs\");\nconst console_js_1 = require(\"../tracers/console.cjs\");\nconst utils_js_1 = require(\"../messages/utils.cjs\");\nconst env_js_1 = require(\"../utils/env.cjs\");\nconst tracer_langchain_js_1 = require(\"../tracers/tracer_langchain.cjs\");\nconst promises_js_1 = require(\"./promises.cjs\");\nconst callbacks_js_1 = require(\"../utils/callbacks.cjs\");\nconst base_js_2 = require(\"../tracers/base.cjs\");\nconst context_js_1 = require(\"../singletons/async_local_storage/context.cjs\");\nfunction parseCallbackConfigArg(arg) {\n if (!arg) {\n return {};\n }\n else if (Array.isArray(arg) || \"name\" in arg) {\n return { callbacks: arg };\n }\n else {\n return arg;\n }\n}\n/**\n * Manage callbacks from different components of LangChain.\n */\nclass BaseCallbackManager {\n setHandler(handler) {\n return this.setHandlers([handler]);\n }\n}\nexports.BaseCallbackManager = BaseCallbackManager;\n/**\n * Base class for run manager in LangChain.\n */\nclass BaseRunManager {\n constructor(runId, handlers, inheritableHandlers, tags, inheritableTags, metadata, inheritableMetadata, _parentRunId) {\n Object.defineProperty(this, \"runId\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: runId\n });\n Object.defineProperty(this, \"handlers\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: handlers\n });\n Object.defineProperty(this, \"inheritableHandlers\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: inheritableHandlers\n });\n Object.defineProperty(this, \"tags\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: tags\n });\n Object.defineProperty(this, \"inheritableTags\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: inheritableTags\n });\n Object.defineProperty(this, \"metadata\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: metadata\n });\n Object.defineProperty(this, \"inheritableMetadata\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: inheritableMetadata\n });\n Object.defineProperty(this, \"_parentRunId\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: _parentRunId\n });\n }\n get parentRunId() {\n return this._parentRunId;\n }\n async handleText(text) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n try {\n await handler.handleText?.(text, this.runId, this._parentRunId, this.tags);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleText: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers)));\n }\n async handleCustomEvent(eventName, \n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data, _runId, _tags, \n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _metadata) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n try {\n await handler.handleCustomEvent?.(eventName, data, this.runId, this.tags, this.metadata);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleCustomEvent: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers)));\n }\n}\nexports.BaseRunManager = BaseRunManager;\n/**\n * Manages callbacks for retriever runs.\n */\nclass CallbackManagerForRetrieverRun extends BaseRunManager {\n getChild(tag) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n async handleRetrieverEnd(documents) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n if (!handler.ignoreRetriever) {\n try {\n await handler.handleRetrieverEnd?.(documents, this.runId, this._parentRunId, this.tags);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleRetriever`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)));\n }\n async handleRetrieverError(err) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n if (!handler.ignoreRetriever) {\n try {\n await handler.handleRetrieverError?.(err, this.runId, this._parentRunId, this.tags);\n }\n catch (error) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleRetrieverError: ${error}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)));\n }\n}\nexports.CallbackManagerForRetrieverRun = CallbackManagerForRetrieverRun;\nclass CallbackManagerForLLMRun extends BaseRunManager {\n async handleLLMNewToken(token, idx, _runId, _parentRunId, _tags, fields) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMNewToken?.(token, idx ?? { prompt: 0, completion: 0 }, this.runId, this._parentRunId, this.tags, fields);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleLLMNewToken: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)));\n }\n async handleLLMError(err, _runId, _parentRunId, _tags, extraParams) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMError?.(err, this.runId, this._parentRunId, this.tags, extraParams);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleLLMError: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)));\n }\n async handleLLMEnd(output, _runId, _parentRunId, _tags, extraParams) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMEnd?.(output, this.runId, this._parentRunId, this.tags, extraParams);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleLLMEnd: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)));\n }\n}\nexports.CallbackManagerForLLMRun = CallbackManagerForLLMRun;\nclass CallbackManagerForChainRun extends BaseRunManager {\n getChild(tag) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n async handleChainError(err, _runId, _parentRunId, _tags, kwargs) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n if (!handler.ignoreChain) {\n try {\n await handler.handleChainError?.(err, this.runId, this._parentRunId, this.tags, kwargs);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleChainError: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)));\n }\n async handleChainEnd(output, _runId, _parentRunId, _tags, kwargs) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n if (!handler.ignoreChain) {\n try {\n await handler.handleChainEnd?.(output, this.runId, this._parentRunId, this.tags, kwargs);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleChainEnd: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)));\n }\n async handleAgentAction(action) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleAgentAction?.(action, this.runId, this._parentRunId, this.tags);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleAgentAction: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)));\n }\n async handleAgentEnd(action) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleAgentEnd?.(action, this.runId, this._parentRunId, this.tags);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleAgentEnd: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)));\n }\n}\nexports.CallbackManagerForChainRun = CallbackManagerForChainRun;\nclass CallbackManagerForToolRun extends BaseRunManager {\n getChild(tag) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n async handleToolError(err) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleToolError?.(err, this.runId, this._parentRunId, this.tags);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleToolError: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)));\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n async handleToolEnd(output) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleToolEnd?.(output, this.runId, this._parentRunId, this.tags);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleToolEnd: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)));\n }\n}\nexports.CallbackManagerForToolRun = CallbackManagerForToolRun;\n/**\n * @example\n * ```typescript\n * const prompt = PromptTemplate.fromTemplate(\"What is the answer to {question}?\");\n *\n * // Example of using LLMChain with OpenAI and a simple prompt\n * const chain = new LLMChain({\n * llm: new ChatOpenAI({ model: \"gpt-4o-mini\", temperature: 0.9 }),\n * prompt,\n * });\n *\n * // Running the chain with a single question\n * const result = await chain.call({\n * question: \"What is the airspeed velocity of an unladen swallow?\",\n * });\n * console.log(\"The answer is:\", result);\n * ```\n */\nclass CallbackManager extends BaseCallbackManager {\n constructor(parentRunId, options) {\n super();\n Object.defineProperty(this, \"handlers\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: []\n });\n Object.defineProperty(this, \"inheritableHandlers\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: []\n });\n Object.defineProperty(this, \"tags\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: []\n });\n Object.defineProperty(this, \"inheritableTags\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: []\n });\n Object.defineProperty(this, \"metadata\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: {}\n });\n Object.defineProperty(this, \"inheritableMetadata\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: {}\n });\n Object.defineProperty(this, \"name\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: \"callback_manager\"\n });\n Object.defineProperty(this, \"_parentRunId\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.handlers = options?.handlers ?? this.handlers;\n this.inheritableHandlers =\n options?.inheritableHandlers ?? this.inheritableHandlers;\n this.tags = options?.tags ?? this.tags;\n this.inheritableTags = options?.inheritableTags ?? this.inheritableTags;\n this.metadata = options?.metadata ?? this.metadata;\n this.inheritableMetadata =\n options?.inheritableMetadata ?? this.inheritableMetadata;\n this._parentRunId = parentRunId;\n }\n /**\n * Gets the parent run ID, if any.\n *\n * @returns The parent run ID.\n */\n getParentRunId() {\n return this._parentRunId;\n }\n async handleLLMStart(llm, prompts, runId = undefined, _parentRunId = undefined, extraParams = undefined, _tags = undefined, _metadata = undefined, runName = undefined) {\n return Promise.all(prompts.map(async (prompt, idx) => {\n // Can't have duplicate runs with the same run ID (if provided)\n const runId_ = idx === 0 && runId ? runId : (0, uuid_1.v4)();\n await Promise.all(this.handlers.map((handler) => {\n if (handler.ignoreLLM) {\n return;\n }\n if ((0, base_js_2.isBaseTracer)(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForLLMStart(llm, [prompt], runId_, this._parentRunId, extraParams, this.tags, this.metadata, runName);\n }\n return (0, promises_js_1.consumeCallback)(async () => {\n try {\n await handler.handleLLMStart?.(llm, [prompt], runId_, this._parentRunId, extraParams, this.tags, this.metadata, runName);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleLLMStart: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n }));\n return new CallbackManagerForLLMRun(runId_, this.handlers, this.inheritableHandlers, this.tags, this.inheritableTags, this.metadata, this.inheritableMetadata, this._parentRunId);\n }));\n }\n async handleChatModelStart(llm, messages, runId = undefined, _parentRunId = undefined, extraParams = undefined, _tags = undefined, _metadata = undefined, runName = undefined) {\n return Promise.all(messages.map(async (messageGroup, idx) => {\n // Can't have duplicate runs with the same run ID (if provided)\n const runId_ = idx === 0 && runId ? runId : (0, uuid_1.v4)();\n await Promise.all(this.handlers.map((handler) => {\n if (handler.ignoreLLM) {\n return;\n }\n if ((0, base_js_2.isBaseTracer)(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForChatModelStart(llm, [messageGroup], runId_, this._parentRunId, extraParams, this.tags, this.metadata, runName);\n }\n return (0, promises_js_1.consumeCallback)(async () => {\n try {\n if (handler.handleChatModelStart) {\n await handler.handleChatModelStart?.(llm, [messageGroup], runId_, this._parentRunId, extraParams, this.tags, this.metadata, runName);\n }\n else if (handler.handleLLMStart) {\n const messageString = (0, utils_js_1.getBufferString)(messageGroup);\n await handler.handleLLMStart?.(llm, [messageString], runId_, this._parentRunId, extraParams, this.tags, this.metadata, runName);\n }\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleLLMStart: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n }));\n return new CallbackManagerForLLMRun(runId_, this.handlers, this.inheritableHandlers, this.tags, this.inheritableTags, this.metadata, this.inheritableMetadata, this._parentRunId);\n }));\n }\n async handleChainStart(chain, inputs, runId = (0, uuid_1.v4)(), runType = undefined, _tags = undefined, _metadata = undefined, runName = undefined) {\n await Promise.all(this.handlers.map((handler) => {\n if (handler.ignoreChain) {\n return;\n }\n if ((0, base_js_2.isBaseTracer)(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForChainStart(chain, inputs, runId, this._parentRunId, this.tags, this.metadata, runType, runName);\n }\n return (0, promises_js_1.consumeCallback)(async () => {\n try {\n await handler.handleChainStart?.(chain, inputs, runId, this._parentRunId, this.tags, this.metadata, runType, runName);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleChainStart: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n }));\n return new CallbackManagerForChainRun(runId, this.handlers, this.inheritableHandlers, this.tags, this.inheritableTags, this.metadata, this.inheritableMetadata, this._parentRunId);\n }\n async handleToolStart(tool, input, runId = (0, uuid_1.v4)(), _parentRunId = undefined, _tags = undefined, _metadata = undefined, runName = undefined) {\n await Promise.all(this.handlers.map((handler) => {\n if (handler.ignoreAgent) {\n return;\n }\n if ((0, base_js_2.isBaseTracer)(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForToolStart(tool, input, runId, this._parentRunId, this.tags, this.metadata, runName);\n }\n return (0, promises_js_1.consumeCallback)(async () => {\n try {\n await handler.handleToolStart?.(tool, input, runId, this._parentRunId, this.tags, this.metadata, runName);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleToolStart: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n }));\n return new CallbackManagerForToolRun(runId, this.handlers, this.inheritableHandlers, this.tags, this.inheritableTags, this.metadata, this.inheritableMetadata, this._parentRunId);\n }\n async handleRetrieverStart(retriever, query, runId = (0, uuid_1.v4)(), _parentRunId = undefined, _tags = undefined, _metadata = undefined, runName = undefined) {\n await Promise.all(this.handlers.map((handler) => {\n if (handler.ignoreRetriever) {\n return;\n }\n if ((0, base_js_2.isBaseTracer)(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForRetrieverStart(retriever, query, runId, this._parentRunId, this.tags, this.metadata, runName);\n }\n return (0, promises_js_1.consumeCallback)(async () => {\n try {\n await handler.handleRetrieverStart?.(retriever, query, runId, this._parentRunId, this.tags, this.metadata, runName);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleRetrieverStart: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n }));\n return new CallbackManagerForRetrieverRun(runId, this.handlers, this.inheritableHandlers, this.tags, this.inheritableTags, this.metadata, this.inheritableMetadata, this._parentRunId);\n }\n async handleCustomEvent(eventName, \n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data, runId, _tags, \n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _metadata) {\n await Promise.all(this.handlers.map((handler) => (0, promises_js_1.consumeCallback)(async () => {\n if (!handler.ignoreCustomEvent) {\n try {\n await handler.handleCustomEvent?.(eventName, data, runId, this.tags, this.metadata);\n }\n catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(`Error in handler ${handler.constructor.name}, handleCustomEvent: ${err}`);\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)));\n }\n addHandler(handler, inherit = true) {\n this.handlers.push(handler);\n if (inherit) {\n this.inheritableHandlers.push(handler);\n }\n }\n removeHandler(handler) {\n this.handlers = this.handlers.filter((_handler) => _handler !== handler);\n this.inheritableHandlers = this.inheritableHandlers.filter((_handler) => _handler !== handler);\n }\n setHandlers(handlers, inherit = true) {\n this.handlers = [];\n this.inheritableHandlers = [];\n for (const handler of handlers) {\n this.addHandler(handler, inherit);\n }\n }\n addTags(tags, inherit = true) {\n this.removeTags(tags); // Remove duplicates\n this.tags.push(...tags);\n if (inherit) {\n this.inheritableTags.push(...tags);\n }\n }\n removeTags(tags) {\n this.tags = this.tags.filter((tag) => !tags.includes(tag));\n this.inheritableTags = this.inheritableTags.filter((tag) => !tags.includes(tag));\n }\n addMetadata(metadata, inherit = true) {\n this.metadata = { ...this.metadata, ...metadata };\n if (inherit) {\n this.inheritableMetadata = { ...this.inheritableMetadata, ...metadata };\n }\n }\n removeMetadata(metadata) {\n for (const key of Object.keys(metadata)) {\n delete this.metadata[key];\n delete this.inheritableMetadata[key];\n }\n }\n copy(additionalHandlers = [], inherit = true) {\n const manager = new CallbackManager(this._parentRunId);\n for (const handler of this.handlers) {\n const inheritable = this.inheritableHandlers.includes(handler);\n manager.addHandler(handler, inheritable);\n }\n for (const tag of this.tags) {\n const inheritable = this.inheritableTags.includes(tag);\n manager.addTags([tag], inheritable);\n }\n for (const key of Object.keys(this.metadata)) {\n const inheritable = Object.keys(this.inheritableMetadata).includes(key);\n manager.addMetadata({ [key]: this.metadata[key] }, inheritable);\n }\n for (const handler of additionalHandlers) {\n if (\n // Prevent multiple copies of console_callback_handler\n manager.handlers\n .filter((h) => h.name === \"console_callback_handler\")\n .some((h) => h.name === handler.name)) {\n continue;\n }\n manager.addHandler(handler, inherit);\n }\n return manager;\n }\n static fromHandlers(handlers) {\n class Handler extends base_js_1.BaseCallbackHandler {\n constructor() {\n super();\n Object.defineProperty(this, \"name\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: (0, uuid_1.v4)()\n });\n Object.assign(this, handlers);\n }\n }\n const manager = new this();\n manager.addHandler(new Handler());\n return manager;\n }\n static configure(inheritableHandlers, localHandlers, inheritableTags, localTags, inheritableMetadata, localMetadata, options) {\n return this._configureSync(inheritableHandlers, localHandlers, inheritableTags, localTags, inheritableMetadata, localMetadata, options);\n }\n // TODO: Deprecate async method in favor of this one.\n static _configureSync(inheritableHandlers, localHandlers, inheritableTags, localTags, inheritableMetadata, localMetadata, options) {\n let callbackManager;\n if (inheritableHandlers || localHandlers) {\n if (Array.isArray(inheritableHandlers) || !inheritableHandlers) {\n callbackManager = new CallbackManager();\n callbackManager.setHandlers(inheritableHandlers?.map(ensureHandler) ?? [], true);\n }\n else {\n callbackManager = inheritableHandlers;\n }\n callbackManager = callbackManager.copy(Array.isArray(localHandlers)\n ? localHandlers.map(ensureHandler)\n : localHandlers?.handlers, false);\n }\n const verboseEnabled = (0, env_js_1.getEnvironmentVariable)(\"LANGCHAIN_VERBOSE\") === \"true\" ||\n options?.verbose;\n const tracingV2Enabled = tracer_langchain_js_1.LangChainTracer.getTraceableRunTree()?.tracingEnabled ||\n (0, callbacks_js_1.isTracingEnabled)();\n const tracingEnabled = tracingV2Enabled ||\n ((0, env_js_1.getEnvironmentVariable)(\"LANGCHAIN_TRACING\") ?? false);\n if (verboseEnabled || tracingEnabled) {\n if (!callbackManager) {\n callbackManager = new CallbackManager();\n }\n if (verboseEnabled &&\n !callbackManager.handlers.some((handler) => handler.name === console_js_1.ConsoleCallbackHandler.prototype.name)) {\n const consoleHandler = new console_js_1.ConsoleCallbackHandler();\n callbackManager.addHandler(consoleHandler, true);\n }\n if (tracingEnabled &&\n !callbackManager.handlers.some((handler) => handler.name === \"langchain_tracer\")) {\n if (tracingV2Enabled) {\n const tracerV2 = new tracer_langchain_js_1.LangChainTracer();\n callbackManager.addHandler(tracerV2, true);\n }\n }\n if (tracingV2Enabled) {\n // handoff between langchain and langsmith/traceable\n // override the parent run ID\n const implicitRunTree = tracer_langchain_js_1.LangChainTracer.getTraceableRunTree();\n if (implicitRunTree && callbackManager._parentRunId === undefined) {\n callbackManager._parentRunId = implicitRunTree.id;\n const tracerV2 = callbackManager.handlers.find((handler) => handler.name === \"langchain_tracer\");\n tracerV2?.updateFromRunTree(implicitRunTree);\n }\n }\n }\n for (const { contextVar, inheritable = true, handlerClass, envVar, } of (0, context_js_1._getConfigureHooks)()) {\n const createIfNotInContext = envVar && (0, env_js_1.getEnvironmentVariable)(envVar) === \"true\" && handlerClass;\n let handler;\n const contextVarValue = contextVar !== undefined ? (0, context_js_1.getContextVariable)(contextVar) : undefined;\n if (contextVarValue && (0, base_js_1.isBaseCallbackHandler)(contextVarValue)) {\n handler = contextVarValue;\n }\n else if (createIfNotInContext) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n handler = new handlerClass({});\n }\n if (handler !== undefined) {\n if (!callbackManager) {\n callbackManager = new CallbackManager();\n }\n if (!callbackManager.handlers.some((h) => h.name === handler.name)) {\n callbackManager.addHandler(handler, inheritable);\n }\n }\n }\n if (inheritableTags || localTags) {\n if (callbackManager) {\n callbackManager.addTags(inheritableTags ?? []);\n callbackManager.addTags(localTags ?? [], false);\n }\n }\n if (inheritableMetadata || localMetadata) {\n if (callbackManager) {\n callbackManager.addMetadata(inheritableMetadata ?? {});\n callbackManager.addMetadata(localMetadata ?? {}, false);\n }\n }\n return callbackManager;\n }\n}\nexports.CallbackManager = CallbackManager;\nfunction ensureHandler(handler) {\n if (\"name\" in handler) {\n return handler;\n }\n return base_js_1.BaseCallbackHandler.fromMethods(handler);\n}\n/**\n * @deprecated Use [`traceable`](https://docs.smith.langchain.com/observability/how_to_guides/tracing/annotate_code)\n * from \"langsmith\" instead.\n */\nclass TraceGroup {\n constructor(groupName, options) {\n Object.defineProperty(this, \"groupName\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: groupName\n });\n Object.defineProperty(this, \"options\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: options\n });\n Object.defineProperty(this, \"runManager\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n }\n async getTraceGroupCallbackManager(group_name, inputs, options) {\n const cb = new tracer_langchain_js_1.LangChainTracer(options);\n const cm = await CallbackManager.configure([cb]);\n const runManager = await cm?.handleChainStart({\n lc: 1,\n type: \"not_implemented\",\n id: [\"langchain\", \"callbacks\", \"groups\", group_name],\n }, inputs ?? {});\n if (!runManager) {\n throw new Error(\"Failed to create run group callback manager.\");\n }\n return runManager;\n }\n async start(inputs) {\n if (!this.runManager) {\n this.runManager = await this.getTraceGroupCallbackManager(this.groupName, inputs, this.options);\n }\n return this.runManager.getChild();\n }\n async error(err) {\n if (this.runManager) {\n await this.runManager.handleChainError(err);\n this.runManager = undefined;\n }\n }\n async end(output) {\n if (this.runManager) {\n await this.runManager.handleChainEnd(output ?? {});\n this.runManager = undefined;\n }\n }\n}\nexports.TraceGroup = TraceGroup;\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _coerceToDict(value, defaultKey) {\n return value && !Array.isArray(value) && typeof value === \"object\"\n ? value\n : { [defaultKey]: value };\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nasync function traceAsGroup(groupOptions, enclosedCode, ...args) {\n const traceGroup = new TraceGroup(groupOptions.name, groupOptions);\n const callbackManager = await traceGroup.start({ ...args });\n try {\n const result = await enclosedCode(callbackManager, ...args);\n await traceGroup.end(_coerceToDict(result, \"output\"));\n return result;\n }\n catch (err) {\n await traceGroup.error(err);\n throw err;\n }\n}\n","module.exports = require('../dist/callbacks/manager.cjs');","import { SpanKind, SpanStatusCode, context } from '@opentelemetry/api';\nimport { InstrumentationBase } from '@opentelemetry/instrumentation';\nimport { SpanAttributes, CONTEXT_KEY_ALLOW_TRACE_CONTENT } from '@traceloop/ai-semantic-conventions';\nimport { __awaiter } from 'tslib';\nimport { BaseCallbackHandler } from '@langchain/core/callbacks/base';\nimport { ATTR_GEN_AI_SYSTEM, ATTR_GEN_AI_PROMPT, ATTR_GEN_AI_COMPLETION, ATTR_GEN_AI_RESPONSE_MODEL, ATTR_GEN_AI_REQUEST_MODEL, ATTR_GEN_AI_USAGE_PROMPT_TOKENS, ATTR_GEN_AI_USAGE_COMPLETION_TOKENS } from '@opentelemetry/semantic-conventions/incubating';\n\n/*\n * Copyright Traceloop\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nclass TraceloopCallbackHandler extends BaseCallbackHandler {\n constructor(tracer, traceContent = true) {\n super();\n this.name = \"traceloop_callback_handler\";\n this.spans = new Map();\n this.tracer = tracer;\n this.traceContent = traceContent;\n }\n handleChatModelStart(llm, messages, runId, _parentRunId, _extraParams, _tags, _metadata, _runName) {\n return __awaiter(this, void 0, void 0, function* () {\n var _a;\n const className = ((_a = llm.id) === null || _a === void 0 ? void 0 : _a[llm.id.length - 1]) || \"unknown\";\n const vendor = this.detectVendor(llm);\n const spanBaseName = this.convertClassNameToSpanName(className);\n // Create single LLM span like Python implementation\n const span = this.tracer.startSpan(spanBaseName, {\n kind: SpanKind.CLIENT,\n });\n const flatMessages = messages.flat();\n span.setAttributes({\n [ATTR_GEN_AI_SYSTEM]: vendor,\n [SpanAttributes.LLM_REQUEST_TYPE]: \"chat\",\n });\n // Add prompts if tracing content\n if (this.traceContent && flatMessages.length > 0) {\n flatMessages.forEach((message, idx) => {\n const role = this.mapMessageTypeToRole(message._getType());\n span.setAttributes({\n [`${ATTR_GEN_AI_PROMPT}.${idx}.role`]: role,\n [`${ATTR_GEN_AI_PROMPT}.${idx}.content`]: typeof message.content === \"string\"\n ? message.content\n : JSON.stringify(message.content),\n });\n });\n }\n this.spans.set(runId, { span, runId });\n });\n }\n handleLLMStart(llm, prompts, runId, _parentRunId, _extraParams, _tags, _metadata, _runName) {\n return __awaiter(this, void 0, void 0, function* () {\n var _a;\n const className = ((_a = llm.id) === null || _a === void 0 ? void 0 : _a[llm.id.length - 1]) || \"unknown\";\n const vendor = this.detectVendor(llm);\n const spanBaseName = this.convertClassNameToSpanName(className);\n // Create single LLM span like handleChatModelStart\n const span = this.tracer.startSpan(spanBaseName, {\n kind: SpanKind.CLIENT,\n });\n span.setAttributes({\n [ATTR_GEN_AI_SYSTEM]: vendor,\n [SpanAttributes.LLM_REQUEST_TYPE]: \"completion\",\n });\n if (this.traceContent && prompts.length > 0) {\n prompts.forEach((prompt, idx) => {\n span.setAttributes({\n [`${ATTR_GEN_AI_PROMPT}.${idx}.role`]: \"user\",\n [`${ATTR_GEN_AI_PROMPT}.${idx}.content`]: prompt,\n });\n });\n }\n this.spans.set(runId, { span, runId });\n });\n }\n handleLLMEnd(output, runId, _parentRunId, _tags, _extraParams) {\n return __awaiter(this, void 0, void 0, function* () {\n var _a, _b;\n const spanData = this.spans.get(runId);\n if (!spanData)\n return;\n const { span } = spanData;\n if (this.traceContent &&\n output.generations &&\n output.generations.length > 0) {\n output.generations.forEach((generation, idx) => {\n if (generation && generation.length > 0) {\n span.setAttributes({\n [`${ATTR_GEN_AI_COMPLETION}.${idx}.role`]: \"assistant\",\n [`${ATTR_GEN_AI_COMPLETION}.${idx}.content`]: generation[0].text,\n });\n }\n });\n }\n // Extract model name from response only, like Python implementation\n const modelName = this.extractModelNameFromResponse(output);\n // Set both request and response model attributes like Python implementation\n span.setAttributes({\n [ATTR_GEN_AI_REQUEST_MODEL]: modelName || \"unknown\",\n [ATTR_GEN_AI_RESPONSE_MODEL]: modelName || \"unknown\",\n });\n // Add usage metrics if available\n if ((_a = output.llmOutput) === null || _a === void 0 ? void 0 : _a.usage) {\n const usage = output.llmOutput.usage;\n if (usage.input_tokens) {\n span.setAttributes({\n [ATTR_GEN_AI_USAGE_PROMPT_TOKENS]: usage.input_tokens,\n });\n }\n if (usage.output_tokens) {\n span.setAttributes({\n [ATTR_GEN_AI_USAGE_COMPLETION_TOKENS]: usage.output_tokens,\n });\n }\n const totalTokens = (usage.input_tokens || 0) + (usage.output_tokens || 0);\n if (totalTokens > 0) {\n span.setAttributes({\n [SpanAttributes.LLM_USAGE_TOTAL_TOKENS]: totalTokens,\n });\n }\n }\n // Also check for tokenUsage format (for compatibility)\n if ((_b = output.llmOutput) === null || _b === void 0 ? void 0 : _b.tokenUsage) {\n const usage = output.llmOutput.tokenUsage;\n if (usage.promptTokens) {\n span.setAttributes({\n [ATTR_GEN_AI_USAGE_PROMPT_TOKENS]: usage.promptTokens,\n });\n }\n if (usage.completionTokens) {\n span.setAttributes({\n [ATTR_GEN_AI_USAGE_COMPLETION_TOKENS]: usage.completionTokens,\n });\n }\n if (usage.totalTokens) {\n span.setAttributes({\n [SpanAttributes.LLM_USAGE_TOTAL_TOKENS]: usage.totalTokens,\n });\n }\n }\n span.setStatus({ code: SpanStatusCode.OK });\n span.end();\n this.spans.delete(runId);\n });\n }\n handleChatModelEnd(output, runId, _parentRunId, _tags, _extraParams) {\n return __awaiter(this, void 0, void 0, function* () {\n // Same as handleLLMEnd for chat models\n return this.handleLLMEnd(output, runId, _parentRunId, _tags, _extraParams);\n });\n }\n handleLLMError(err, runId, _parentRunId, _tags, _extraParams) {\n return __awaiter(this, void 0, void 0, function* () {\n const spanData = this.spans.get(runId);\n if (!spanData)\n return;\n const { span } = spanData;\n span.recordException(err);\n span.setStatus({ code: SpanStatusCode.ERROR, message: err.message });\n span.end();\n this.spans.delete(runId);\n });\n }\n handleChainStart(chain, inputs, runId, _parentRunId, _tags, metadata, runType, runName) {\n return __awaiter(this, void 0, void 0, function* () {\n var _a;\n const chainName = ((_a = chain.id) === null || _a === void 0 ? void 0 : _a[chain.id.length - 1]) || \"unknown\";\n const spanName = `${chainName}.workflow`;\n const span = this.tracer.startSpan(spanName, {\n kind: SpanKind.CLIENT,\n });\n span.setAttributes({\n \"traceloop.span.kind\": \"workflow\",\n \"traceloop.workflow.name\": runName || chainName,\n });\n if (this.traceContent) {\n span.setAttributes({\n \"traceloop.entity.input\": JSON.stringify(inputs),\n });\n }\n this.spans.set(runId, { span, runId });\n });\n }\n handleChainEnd(outputs, runId, _parentRunId, _tags, _kwargs) {\n return __awaiter(this, void 0, void 0, function* () {\n const spanData = this.spans.get(runId);\n if (!spanData)\n return;\n const { span } = spanData;\n if (this.traceContent) {\n span.setAttributes({\n \"traceloop.entity.output\": JSON.stringify(outputs),\n });\n }\n span.setStatus({ code: SpanStatusCode.OK });\n span.end();\n this.spans.delete(runId);\n });\n }\n handleChainError(err, runId, _parentRunId, _tags, _kwargs) {\n return __awaiter(this, void 0, void 0, function* () {\n const spanData = this.spans.get(runId);\n if (!spanData)\n return;\n const { span } = spanData;\n span.recordException(err);\n span.setStatus({ code: SpanStatusCode.ERROR, message: err.message });\n span.end();\n this.spans.delete(runId);\n });\n }\n handleToolStart(tool, input, runId, _parentRunId, _tags, _metadata, _runName) {\n return __awaiter(this, void 0, void 0, function* () {\n var _a;\n const toolName = ((_a = tool.id) === null || _a === void 0 ? void 0 : _a[tool.id.length - 1]) || \"unknown\";\n const spanName = `${toolName}.task`;\n const span = this.tracer.startSpan(spanName, {\n kind: SpanKind.CLIENT,\n });\n span.setAttributes({\n \"traceloop.span.kind\": \"task\",\n \"traceloop.entity.name\": toolName,\n });\n if (this.traceContent) {\n span.setAttributes({\n \"traceloop.entity.input\": JSON.stringify({ args: [input] }),\n });\n }\n this.spans.set(runId, { span, runId });\n });\n }\n handleToolEnd(output, runId, _parentRunId, _tags) {\n return __awaiter(this, void 0, void 0, function* () {\n const spanData = this.spans.get(runId);\n if (!spanData)\n return;\n const { span } = spanData;\n if (this.traceContent) {\n span.setAttributes({\n \"traceloop.entity.output\": JSON.stringify(output),\n });\n }\n span.setStatus({ code: SpanStatusCode.OK });\n span.end();\n this.spans.delete(runId);\n });\n }\n handleToolError(err, runId, _parentRunId, _tags) {\n return __awaiter(this, void 0, void 0, function* () {\n const spanData = this.spans.get(runId);\n if (!spanData)\n return;\n const { span } = spanData;\n span.recordException(err);\n span.setStatus({ code: SpanStatusCode.ERROR, message: err.message });\n span.end();\n this.spans.delete(runId);\n });\n }\n extractModelNameFromResponse(output) {\n // Follow Python implementation - extract from llm_output first\n if (output.llmOutput) {\n const modelName = output.llmOutput.model_name ||\n output.llmOutput.model_id ||\n output.llmOutput.model;\n if (modelName && typeof modelName === \"string\") {\n return modelName;\n }\n }\n return null;\n }\n convertClassNameToSpanName(className) {\n // Convert PascalCase to lowercase with dots\n // BedrockChat -> bedrock.chat\n // ChatOpenAI -> chat.openai\n return className.replace(/([A-Z])/g, (match, char, index) => {\n return index === 0 ? char.toLowerCase() : `.${char.toLowerCase()}`;\n });\n }\n detectVendor(llm) {\n var _a;\n const className = ((_a = llm.id) === null || _a === void 0 ? void 0 : _a[llm.id.length - 1]) || \"\";\n if (!className) {\n return \"Langchain\";\n }\n // Follow Python implementation with exact matches and patterns\n // Ordered by specificity (most specific first)\n // Azure (most specific - check first)\n if ([\"AzureChatOpenAI\", \"AzureOpenAI\", \"AzureOpenAIEmbeddings\"].includes(className) ||\n className.toLowerCase().includes(\"azure\")) {\n return \"Azure\";\n }\n // OpenAI\n if ([\"ChatOpenAI\", \"OpenAI\", \"OpenAIEmbeddings\"].includes(className) ||\n className.toLowerCase().includes(\"openai\")) {\n return \"openai\";\n }\n // AWS Bedrock\n if ([\"ChatBedrock\", \"BedrockEmbeddings\", \"Bedrock\", \"BedrockChat\"].includes(className) ||\n className.toLowerCase().includes(\"bedrock\") ||\n className.toLowerCase().includes(\"aws\")) {\n return \"AWS\";\n }\n // Anthropic\n if ([\"ChatAnthropic\", \"AnthropicLLM\"].includes(className) ||\n className.toLowerCase().includes(\"anthropic\")) {\n return \"Anthropic\";\n }\n // Google (Vertex/PaLM/Gemini)\n if ([\n \"ChatVertexAI\",\n \"VertexAI\",\n \"VertexAIEmbeddings\",\n \"ChatGoogleGenerativeAI\",\n \"GoogleGenerativeAI\",\n \"GooglePaLM\",\n \"ChatGooglePaLM\",\n ].includes(className) ||\n className.toLowerCase().includes(\"vertex\") ||\n className.toLowerCase().includes(\"google\") ||\n className.toLowerCase().includes(\"palm\") ||\n className.toLowerCase().includes(\"gemini\")) {\n return \"Google\";\n }\n // Cohere\n if ([\"ChatCohere\", \"CohereEmbeddings\", \"Cohere\"].includes(className) ||\n className.toLowerCase().includes(\"cohere\")) {\n return \"Cohere\";\n }\n // HuggingFace\n if ([\n \"HuggingFacePipeline\",\n \"HuggingFaceTextGenInference\",\n \"HuggingFaceEmbeddings\",\n \"ChatHuggingFace\",\n ].includes(className) ||\n className.toLowerCase().includes(\"huggingface\")) {\n return \"HuggingFace\";\n }\n // Ollama\n if ([\"ChatOllama\", \"OllamaEmbeddings\", \"Ollama\"].includes(className) ||\n className.toLowerCase().includes(\"ollama\")) {\n return \"Ollama\";\n }\n // Together\n if ([\"Together\", \"ChatTogether\"].includes(className) ||\n className.toLowerCase().includes(\"together\")) {\n return \"TogetherAI\";\n }\n // Replicate\n if ([\"Replicate\", \"ChatReplicate\"].includes(className) ||\n className.toLowerCase().includes(\"replicate\")) {\n return \"Replicate\";\n }\n return \"Langchain\";\n }\n mapMessageTypeToRole(messageType) {\n // Map LangChain message types to standard OpenTelemetry roles\n switch (messageType) {\n case \"human\":\n return \"user\";\n case \"ai\":\n return \"assistant\";\n case \"system\":\n return \"system\";\n case \"function\":\n return \"tool\";\n default:\n return messageType;\n }\n }\n}\n\nvar version = \"0.22.6\";\n\n/*\n * Copyright Traceloop\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and\n * limitations under the License.\n */\nclass LangChainInstrumentation extends InstrumentationBase {\n constructor(config = {}) {\n super(\"@traceloop/instrumentation-langchain\", version, config);\n // Manually instrument CallbackManager immediately since module detection doesn't work\n this.instrumentCallbackManagerDirectly();\n }\n manuallyInstrument({ callbackManagerModule, }) {\n if (callbackManagerModule) {\n this._diag.debug(\"Manually instrumenting @langchain/core/callbacks/manager\");\n this.patchCallbackManager(callbackManagerModule.CallbackManager);\n }\n }\n init() {\n // Return empty array since we handle patching in constructor\n return [];\n }\n instrumentCallbackManagerDirectly() {\n try {\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const callbackManagerModule = require(\"@langchain/core/callbacks/manager\");\n if (callbackManagerModule === null || callbackManagerModule === void 0 ? void 0 : callbackManagerModule.CallbackManager) {\n this.patchCallbackManager(callbackManagerModule.CallbackManager);\n }\n }\n catch (error) {\n this._diag.debug(\"Error instrumenting callback manager:\", error);\n }\n }\n patchCallbackManager(CallbackManager) {\n const callbackManagerAny = CallbackManager;\n if (callbackManagerAny._configureSync &&\n !callbackManagerAny._traceloopPatched) {\n const originalConfigureSync = callbackManagerAny._configureSync;\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const self = this;\n callbackManagerAny._configureSync = function (inheritableHandlers, localHandlers, inheritableTags, localTags, inheritableMetadata, localMetadata) {\n // Add our callback handler to inheritable handlers\n const callbackHandler = new TraceloopCallbackHandler(self.tracer, self._shouldSendPrompts());\n const updatedInheritableHandlers = inheritableHandlers && Array.isArray(inheritableHandlers)\n ? [...inheritableHandlers, callbackHandler]\n : [callbackHandler];\n return originalConfigureSync.call(this, updatedInheritableHandlers, localHandlers, inheritableTags, localTags, inheritableMetadata, localMetadata);\n };\n // Mark as patched to avoid double patching\n callbackManagerAny._traceloopPatched = true;\n }\n }\n _shouldSendPrompts() {\n const contextShouldSendPrompts = context\n .active()\n .getValue(CONTEXT_KEY_ALLOW_TRACE_CONTENT);\n if (contextShouldSendPrompts !== undefined) {\n return !!contextShouldSendPrompts;\n }\n return this._config.traceContent !== undefined\n ? this._config.traceContent\n : true;\n }\n}\n\nexport { LangChainInstrumentation, TraceloopCallbackHandler };\n//# sourceMappingURL=index.mjs.map\n","/******************************************************************************\nCopyright (c) Microsoft Corporation.\n\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\n\nvar extendStatics = function(d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n};\n\nexport function __extends(d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\n\nexport var __assign = function() {\n __assign = Object.assign || function __assign(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n }\n return __assign.apply(this, arguments);\n}\n\nexport function __rest(s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n}\n\nexport function __decorate(decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n 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;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\n\nexport function __param(paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n}\n\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\n var _, done = false;\n for (var i = decorators.length - 1; i >= 0; i--) {\n var context = {};\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\n if (kind === \"accessor\") {\n if (result === void 0) continue;\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\n if (_ = accept(result.get)) descriptor.get = _;\n if (_ = accept(result.set)) descriptor.set = _;\n if (_ = accept(result.init)) initializers.unshift(_);\n }\n else if (_ = accept(result)) {\n if (kind === \"field\") initializers.unshift(_);\n else descriptor[key] = _;\n }\n }\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\n done = true;\n};\n\nexport function __runInitializers(thisArg, initializers, value) {\n var useValue = arguments.length > 2;\n for (var i = 0; i < initializers.length; i++) {\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\n }\n return useValue ? value : void 0;\n};\n\nexport function __propKey(x) {\n return typeof x === \"symbol\" ? x : \"\".concat(x);\n};\n\nexport function __setFunctionName(f, name, prefix) {\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\n};\n\nexport function __metadata(metadataKey, metadataValue) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\n\nexport function __awaiter(thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n}\n\nexport function __generator(thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n}\n\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\n\nexport function __exportStar(m, o) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n}\n\nexport function __values(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\n\nexport function __read(o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n}\n\n/** @deprecated */\nexport function __spread() {\n for (var ar = [], i = 0; i < arguments.length; i++)\n ar = ar.concat(__read(arguments[i]));\n return ar;\n}\n\n/** @deprecated */\nexport function __spreadArrays() {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n}\n\nexport function __spreadArray(to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n}\n\nexport function __await(v) {\n return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\n\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\n function fulfill(value) { resume(\"next\", value); }\n function reject(value) { resume(\"throw\", value); }\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\n}\n\nexport function __asyncDelegator(o) {\n var i, p;\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\n}\n\nexport function __asyncValues(o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator], i;\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\n}\n\nexport function __makeTemplateObject(cooked, raw) {\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\n return cooked;\n};\n\nvar __setModuleDefault = Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n};\n\nvar ownKeys = function(o) {\n ownKeys = Object.getOwnPropertyNames || function (o) {\n var ar = [];\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\n return ar;\n };\n return ownKeys(o);\n};\n\nexport function __importStar(mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\n __setModuleDefault(result, mod);\n return result;\n}\n\nexport function __importDefault(mod) {\n return (mod && mod.__esModule) ? mod : { default: mod };\n}\n\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n}\n\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\n}\n\nexport function __classPrivateFieldIn(state, receiver) {\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\n}\n\nexport function __addDisposableResource(env, value, async) {\n if (value !== null && value !== void 0) {\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\n var dispose, inner;\n if (async) {\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\n dispose = value[Symbol.asyncDispose];\n }\n if (dispose === void 0) {\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\n dispose = value[Symbol.dispose];\n if (async) inner = dispose;\n }\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\n env.stack.push({ value: value, dispose: dispose, async: async });\n }\n else if (async) {\n env.stack.push({ async: true });\n }\n return value;\n}\n\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\n var e = new Error(message);\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\n};\n\nexport function __disposeResources(env) {\n function fail(e) {\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\n env.hasError = true;\n }\n var r, s = 0;\n function next() {\n while (r = env.stack.pop()) {\n try {\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\n if (r.dispose) {\n var result = r.dispose.call(r.value);\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\n }\n else s |= 1;\n }\n catch (e) {\n fail(e);\n }\n }\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\n if (env.hasError) throw env.error;\n }\n return next();\n}\n\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\n });\n }\n return path;\n}\n\nexport default {\n __extends,\n __assign,\n __rest,\n __decorate,\n __param,\n __esDecorate,\n __runInitializers,\n __propKey,\n __setFunctionName,\n __metadata,\n __awaiter,\n __generator,\n __createBinding,\n __exportStar,\n __values,\n __read,\n __spread,\n __spreadArrays,\n __spreadArray,\n __await,\n __asyncGenerator,\n __asyncDelegator,\n __asyncValues,\n __makeTemplateObject,\n __importStar,\n __importDefault,\n __classPrivateFieldGet,\n __classPrivateFieldSet,\n __classPrivateFieldIn,\n __addDisposableResource,\n __disposeResources,\n __rewriteRelativeImportExtension,\n};\n","import * as uuid from \"uuid\";\nimport { Serializable, get_lc_unique_name, } from \"../load/serializable.js\";\nimport { getEnvironmentVariable } from \"../utils/env.js\";\n/**\n * Abstract class that provides a set of optional methods that can be\n * overridden in derived classes to handle various events during the\n * execution of a LangChain application.\n */\nclass BaseCallbackHandlerMethodsClass {\n}\nexport function callbackHandlerPrefersStreaming(x) {\n return \"lc_prefer_streaming\" in x && x.lc_prefer_streaming;\n}\n/**\n * Abstract base class for creating callback handlers in the LangChain\n * framework. It provides a set of optional methods that can be overridden\n * in derived classes to handle various events during the execution of a\n * LangChain application.\n */\nexport class BaseCallbackHandler extends BaseCallbackHandlerMethodsClass {\n get lc_namespace() {\n return [\"langchain_core\", \"callbacks\", this.name];\n }\n get lc_secrets() {\n return undefined;\n }\n get lc_attributes() {\n return undefined;\n }\n get lc_aliases() {\n return undefined;\n }\n get lc_serializable_keys() {\n return undefined;\n }\n /**\n * The name of the serializable. Override to provide an alias or\n * to preserve the serialized module name in minified environments.\n *\n * Implemented as a static method to support loading logic.\n */\n static lc_name() {\n return this.name;\n }\n /**\n * The final serialized identifier for the module.\n */\n get lc_id() {\n return [\n ...this.lc_namespace,\n get_lc_unique_name(this.constructor),\n ];\n }\n constructor(input) {\n super();\n Object.defineProperty(this, \"lc_serializable\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"lc_kwargs\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n Object.defineProperty(this, \"ignoreLLM\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"ignoreChain\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"ignoreAgent\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"ignoreRetriever\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"ignoreCustomEvent\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"raiseError\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"awaitHandlers\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: getEnvironmentVariable(\"LANGCHAIN_CALLBACKS_BACKGROUND\") === \"false\"\n });\n this.lc_kwargs = input || {};\n if (input) {\n this.ignoreLLM = input.ignoreLLM ?? this.ignoreLLM;\n this.ignoreChain = input.ignoreChain ?? this.ignoreChain;\n this.ignoreAgent = input.ignoreAgent ?? this.ignoreAgent;\n this.ignoreRetriever = input.ignoreRetriever ?? this.ignoreRetriever;\n this.ignoreCustomEvent =\n input.ignoreCustomEvent ?? this.ignoreCustomEvent;\n this.raiseError = input.raiseError ?? this.raiseError;\n this.awaitHandlers =\n this.raiseError || (input._awaitHandler ?? this.awaitHandlers);\n }\n }\n copy() {\n return new this.constructor(this);\n }\n toJSON() {\n return Serializable.prototype.toJSON.call(this);\n }\n toJSONNotImplemented() {\n return Serializable.prototype.toJSONNotImplemented.call(this);\n }\n static fromMethods(methods) {\n class Handler extends BaseCallbackHandler {\n constructor() {\n super();\n Object.defineProperty(this, \"name\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: uuid.v4()\n });\n Object.assign(this, methods);\n }\n }\n return new Handler();\n }\n}\nexport const isBaseCallbackHandler = (x) => {\n const callbackHandler = x;\n return (callbackHandler !== undefined &&\n typeof callbackHandler.copy === \"function\" &&\n typeof callbackHandler.name === \"string\" &&\n typeof callbackHandler.awaitHandlers === \"boolean\");\n};\n","import snakeCase from \"decamelize\";\nimport camelCase from \"camelcase\";\nexport function keyToJson(key, map) {\n return map?.[key] || snakeCase(key);\n}\nexport function keyFromJson(key, map) {\n return map?.[key] || camelCase(key);\n}\nexport function mapKeys(fields, mapper, map) {\n const mapped = {};\n for (const key in fields) {\n if (Object.hasOwn(fields, key)) {\n mapped[mapper(key, map)] = fields[key];\n }\n }\n return mapped;\n}\n","/**\n * Sentinel key used to mark escaped user objects during serialization.\n *\n * When a plain object contains 'lc' key (which could be confused with LC objects),\n * we wrap it as `{\"__lc_escaped__\": {...original...}}`.\n */\nexport const LC_ESCAPED_KEY = \"__lc_escaped__\";\n/**\n * Check if an object needs escaping to prevent confusion with LC objects.\n *\n * An object needs escaping if:\n * 1. It has an `'lc'` key (could be confused with LC serialization format)\n * 2. It has only the escape key (would be mistaken for an escaped object)\n */\nexport function needsEscaping(obj) {\n return (\"lc\" in obj || (Object.keys(obj).length === 1 && LC_ESCAPED_KEY in obj));\n}\n/**\n * Wrap an object in the escape marker.\n *\n * @example\n * ```typescript\n * {\"key\": \"value\"} // becomes {\"__lc_escaped__\": {\"key\": \"value\"}}\n * ```\n */\nexport function escapeObject(obj) {\n return { [LC_ESCAPED_KEY]: obj };\n}\n/**\n * Check if an object is an escaped user object.\n *\n * @example\n * ```typescript\n * {\"__lc_escaped__\": {...}} // is an escaped object\n * ```\n */\nexport function isEscapedObject(obj) {\n return Object.keys(obj).length === 1 && LC_ESCAPED_KEY in obj;\n}\n/**\n * Check if an object looks like a Serializable instance (duck typing).\n */\nfunction isSerializableLike(obj) {\n return (obj !== null &&\n typeof obj === \"object\" &&\n \"lc_serializable\" in obj &&\n typeof obj.toJSON === \"function\");\n}\n/**\n * Create a \"not_implemented\" serialization result for objects that cannot be serialized.\n */\nfunction createNotImplemented(obj) {\n let id;\n if (obj !== null && typeof obj === \"object\") {\n if (\"lc_id\" in obj && Array.isArray(obj.lc_id)) {\n id = obj.lc_id;\n }\n else {\n id = [obj.constructor?.name ?? \"Object\"];\n }\n }\n else {\n id = [typeof obj];\n }\n return {\n lc: 1,\n type: \"not_implemented\",\n id,\n };\n}\n/**\n * Serialize a value with escaping of user objects.\n *\n * Called recursively on kwarg values to escape any plain objects that could be\n * confused with LC objects.\n *\n * @param obj - The value to serialize.\n * @returns The serialized value with user objects escaped as needed.\n */\nexport function serializeValue(obj) {\n if (isSerializableLike(obj)) {\n // This is an LC object - serialize it properly (not escaped)\n return serializeLcObject(obj);\n }\n if (obj !== null && typeof obj === \"object\" && !Array.isArray(obj)) {\n const record = obj;\n // Check if object needs escaping BEFORE recursing into values.\n // If it needs escaping, wrap it as-is - the contents are user data that\n // will be returned as-is during deserialization (no instantiation).\n // This prevents re-escaping of already-escaped nested content.\n if (needsEscaping(record)) {\n return escapeObject(record);\n }\n // Safe object (no 'lc' key) - recurse into values\n const result = {};\n for (const [key, value] of Object.entries(record)) {\n result[key] = serializeValue(value);\n }\n return result;\n }\n if (Array.isArray(obj)) {\n return obj.map((item) => serializeValue(item));\n }\n if (typeof obj === \"string\" ||\n typeof obj === \"number\" ||\n typeof obj === \"boolean\" ||\n obj === null) {\n return obj;\n }\n // Non-JSON-serializable object (Date, custom objects, etc.)\n return createNotImplemented(obj);\n}\n/**\n * Serialize a `Serializable` object with escaping of user data in kwargs.\n *\n * @param obj - The `Serializable` object to serialize.\n * @returns The serialized object with user data in kwargs escaped as needed.\n *\n * @remarks\n * Kwargs values are processed with `serializeValue` to escape user data (like\n * metadata) that contains `'lc'` keys. Secret fields (from `lc_secrets`) are\n * skipped because `toJSON()` replaces their values with secret markers.\n */\nexport function serializeLcObject(obj) {\n // Secret fields are handled by toJSON() - it replaces values with secret markers\n const secretFields = new Set(Object.keys(obj.lc_secrets ?? {}));\n const serialized = { ...obj.toJSON() };\n // Process kwargs to escape user data that could be confused with LC objects\n // Skip secret fields - toJSON() already converted them to secret markers\n if (serialized.type === \"constructor\" && serialized.kwargs) {\n const newKwargs = {};\n for (const [key, value] of Object.entries(serialized.kwargs)) {\n if (secretFields.has(key)) {\n newKwargs[key] = value;\n }\n else {\n newKwargs[key] = serializeValue(value);\n }\n }\n serialized.kwargs = newKwargs;\n }\n return serialized;\n}\n/**\n * Escape a value if it needs escaping (contains `lc` key).\n *\n * This is a simpler version of `serializeValue` that doesn't handle Serializable\n * objects - it's meant to be called on kwargs values that have already been\n * processed by `toJSON()`.\n *\n * @param value - The value to potentially escape.\n * @returns The value with any `lc`-containing objects wrapped in escape markers.\n */\nexport function escapeIfNeeded(value) {\n if (value !== null && typeof value === \"object\" && !Array.isArray(value)) {\n // Preserve Serializable objects - they have their own toJSON() that will be\n // called by JSON.stringify. We don't want to convert them to plain objects.\n if (isSerializableLike(value)) {\n return value;\n }\n const record = value;\n // Check if object needs escaping BEFORE recursing into values.\n // If it needs escaping, wrap it as-is - the contents are user data that\n // will be returned as-is during deserialization (no instantiation).\n if (needsEscaping(record)) {\n return escapeObject(record);\n }\n // Safe object (no 'lc' key) - recurse into values\n const result = {};\n for (const [key, val] of Object.entries(record)) {\n result[key] = escapeIfNeeded(val);\n }\n return result;\n }\n if (Array.isArray(value)) {\n return value.map((item) => escapeIfNeeded(item));\n }\n return value;\n}\n/**\n * Unescape a value, processing escape markers in object values and arrays.\n *\n * When an escaped object is encountered (`{\"__lc_escaped__\": ...}`), it's\n * unwrapped and the contents are returned AS-IS (no further processing).\n * The contents represent user data that should not be modified.\n *\n * For regular objects and arrays, we recurse to find any nested escape markers.\n *\n * @param obj - The value to unescape.\n * @returns The unescaped value.\n */\nexport function unescapeValue(obj) {\n if (obj !== null && typeof obj === \"object\" && !Array.isArray(obj)) {\n const record = obj;\n if (isEscapedObject(record)) {\n // Unwrap and return the user data as-is (no further unescaping).\n // The contents are user data that may contain more escape keys,\n // but those are part of the user's actual data.\n return record[LC_ESCAPED_KEY];\n }\n // Regular object - recurse into values to find nested escape markers\n const result = {};\n for (const [key, value] of Object.entries(record)) {\n result[key] = unescapeValue(value);\n }\n return result;\n }\n if (Array.isArray(obj)) {\n return obj.map((item) => unescapeValue(item));\n }\n return obj;\n}\n","import { keyToJson, mapKeys } from \"./map_keys.js\";\nimport { escapeIfNeeded } from \"./validation.js\";\nfunction shallowCopy(obj) {\n return Array.isArray(obj) ? [...obj] : { ...obj };\n}\nfunction replaceSecrets(root, secretsMap) {\n const result = shallowCopy(root);\n for (const [path, secretId] of Object.entries(secretsMap)) {\n const [last, ...partsReverse] = path.split(\".\").reverse();\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let current = result;\n for (const part of partsReverse.reverse()) {\n if (current[part] === undefined) {\n break;\n }\n current[part] = shallowCopy(current[part]);\n current = current[part];\n }\n if (current[last] !== undefined) {\n current[last] = {\n lc: 1,\n type: \"secret\",\n id: [secretId],\n };\n }\n }\n return result;\n}\n/**\n * Get a unique name for the module, rather than parent class implementations.\n * Should not be subclassed, subclass lc_name above instead.\n */\nexport function get_lc_unique_name(\n// eslint-disable-next-line @typescript-eslint/no-use-before-define\nserializableClass) {\n // \"super\" here would refer to the parent class of Serializable,\n // when we want the parent class of the module actually calling this method.\n const parentClass = Object.getPrototypeOf(serializableClass);\n const lcNameIsSubclassed = typeof serializableClass.lc_name === \"function\" &&\n (typeof parentClass.lc_name !== \"function\" ||\n serializableClass.lc_name() !== parentClass.lc_name());\n if (lcNameIsSubclassed) {\n return serializableClass.lc_name();\n }\n else {\n return serializableClass.name;\n }\n}\nexport class Serializable {\n /**\n * The name of the serializable. Override to provide an alias or\n * to preserve the serialized module name in minified environments.\n *\n * Implemented as a static method to support loading logic.\n */\n static lc_name() {\n return this.name;\n }\n /**\n * The final serialized identifier for the module.\n */\n get lc_id() {\n return [\n ...this.lc_namespace,\n get_lc_unique_name(this.constructor),\n ];\n }\n /**\n * A map of secrets, which will be omitted from serialization.\n * Keys are paths to the secret in constructor args, e.g. \"foo.bar.baz\".\n * Values are the secret ids, which will be used when deserializing.\n */\n get lc_secrets() {\n return undefined;\n }\n /**\n * A map of additional attributes to merge with constructor args.\n * Keys are the attribute names, e.g. \"foo\".\n * Values are the attribute values, which will be serialized.\n * These attributes need to be accepted by the constructor as arguments.\n */\n get lc_attributes() {\n return undefined;\n }\n /**\n * A map of aliases for constructor args.\n * Keys are the attribute names, e.g. \"foo\".\n * Values are the alias that will replace the key in serialization.\n * This is used to eg. make argument names match Python.\n */\n get lc_aliases() {\n return undefined;\n }\n /**\n * A manual list of keys that should be serialized.\n * If not overridden, all fields passed into the constructor will be serialized.\n */\n get lc_serializable_keys() {\n return undefined;\n }\n constructor(kwargs, ..._args) {\n Object.defineProperty(this, \"lc_serializable\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: false\n });\n Object.defineProperty(this, \"lc_kwargs\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n if (this.lc_serializable_keys !== undefined) {\n this.lc_kwargs = Object.fromEntries(Object.entries(kwargs || {}).filter(([key]) => this.lc_serializable_keys?.includes(key)));\n }\n else {\n this.lc_kwargs = kwargs ?? {};\n }\n }\n toJSON() {\n if (!this.lc_serializable) {\n return this.toJSONNotImplemented();\n }\n if (\n // eslint-disable-next-line no-instanceof/no-instanceof\n this.lc_kwargs instanceof Serializable ||\n typeof this.lc_kwargs !== \"object\" ||\n Array.isArray(this.lc_kwargs)) {\n // We do not support serialization of classes with arg not a POJO\n // I'm aware the check above isn't as strict as it could be\n return this.toJSONNotImplemented();\n }\n const aliases = {};\n const secrets = {};\n const kwargs = Object.keys(this.lc_kwargs).reduce((acc, key) => {\n acc[key] = key in this ? this[key] : this.lc_kwargs[key];\n return acc;\n }, {});\n // get secrets, attributes and aliases from all superclasses\n for (\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let current = Object.getPrototypeOf(this); current; current = Object.getPrototypeOf(current)) {\n Object.assign(aliases, Reflect.get(current, \"lc_aliases\", this));\n Object.assign(secrets, Reflect.get(current, \"lc_secrets\", this));\n Object.assign(kwargs, Reflect.get(current, \"lc_attributes\", this));\n }\n // include all secrets used, even if not in kwargs,\n // will be replaced with sentinel value in replaceSecrets\n Object.keys(secrets).forEach((keyPath) => {\n // eslint-disable-next-line @typescript-eslint/no-this-alias, @typescript-eslint/no-explicit-any\n let read = this;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let write = kwargs;\n const [last, ...partsReverse] = keyPath.split(\".\").reverse();\n for (const key of partsReverse.reverse()) {\n if (!(key in read) || read[key] === undefined)\n return;\n if (!(key in write) || write[key] === undefined) {\n if (typeof read[key] === \"object\" && read[key] != null) {\n write[key] = {};\n }\n else if (Array.isArray(read[key])) {\n write[key] = [];\n }\n }\n read = read[key];\n write = write[key];\n }\n if (last in read && read[last] !== undefined) {\n write[last] = write[last] || read[last];\n }\n });\n const escapedKwargs = {};\n for (const [key, value] of Object.entries(kwargs)) {\n escapedKwargs[key] = escapeIfNeeded(value);\n }\n // Now add secret markers - these are added AFTER escaping so they won't be escaped\n const kwargsWithSecrets = Object.keys(secrets).length\n ? replaceSecrets(escapedKwargs, secrets)\n : escapedKwargs;\n // Finally transform keys to JSON format\n const processedKwargs = mapKeys(kwargsWithSecrets, keyToJson, aliases);\n return {\n lc: 1,\n type: \"constructor\",\n id: this.lc_id,\n kwargs: processedKwargs,\n };\n }\n toJSONNotImplemented() {\n return {\n lc: 1,\n type: \"not_implemented\",\n id: this.lc_id,\n };\n }\n}\n","export const isBrowser = () => typeof window !== \"undefined\" && typeof window.document !== \"undefined\";\nexport const isWebWorker = () => typeof globalThis === \"object\" &&\n globalThis.constructor &&\n globalThis.constructor.name === \"DedicatedWorkerGlobalScope\";\nexport const isJsDom = () => (typeof window !== \"undefined\" && window.name === \"nodejs\") ||\n (typeof navigator !== \"undefined\" && navigator.userAgent.includes(\"jsdom\"));\n// Supabase Edge Function provides a `Deno` global object\n// without `version` property\nexport const isDeno = () => typeof Deno !== \"undefined\";\n// Mark not-as-node if in Supabase Edge Function\nexport const isNode = () => typeof process !== \"undefined\" &&\n typeof process.versions !== \"undefined\" &&\n typeof process.versions.node !== \"undefined\" &&\n !isDeno();\nexport const getEnv = () => {\n let env;\n if (isBrowser()) {\n env = \"browser\";\n }\n else if (isNode()) {\n env = \"node\";\n }\n else if (isWebWorker()) {\n env = \"webworker\";\n }\n else if (isJsDom()) {\n env = \"jsdom\";\n }\n else if (isDeno()) {\n env = \"deno\";\n }\n else {\n env = \"other\";\n }\n return env;\n};\nlet runtimeEnvironment;\n/**\n * @deprecated Use getRuntimeEnvironmentSync instead\n */\nexport async function getRuntimeEnvironment() {\n return getRuntimeEnvironmentSync();\n}\nexport function getRuntimeEnvironmentSync() {\n if (runtimeEnvironment === undefined) {\n const env = getEnv();\n runtimeEnvironment = {\n library: \"langchain-js\",\n runtime: env,\n };\n }\n return runtimeEnvironment;\n}\nexport function getEnvironmentVariable(name) {\n // Certain Deno setups will throw an error if you try to access environment variables\n // https://github.com/langchain-ai/langchainjs/issues/1412\n try {\n if (typeof process !== \"undefined\") {\n // eslint-disable-next-line no-process-env\n return process.env?.[name];\n }\n else if (isDeno()) {\n return Deno?.env.get(name);\n }\n else {\n return undefined;\n }\n }\n catch (e) {\n return undefined;\n }\n}\n","/*\n * Copyright The OpenTelemetry Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n//----------------------------------------------------------------------------------------------------------\n// DO NOT EDIT, this is an Auto-generated file from scripts/semconv/templates/registry/stable/attributes.ts.j2\n//----------------------------------------------------------------------------------------------------------\n\n/**\n * This attribute represents the state of the application.\n *\n * @example created\n *\n * @note The Android lifecycle states are defined in [Activity lifecycle callbacks](https://developer.android.com/guide/components/activities/activity-lifecycle#lc), and from which the `OS identifiers` are derived.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ANDROID_APP_STATE = 'android.app.state' as const;\n\n/**\n * Enum value \"background\" for attribute {@link ATTR_ANDROID_APP_STATE}.\n *\n * Any time after Activity.onPause() or, if the app has no Activity, Context.stopService() has been called when the app was in the foreground state.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ANDROID_APP_STATE_VALUE_BACKGROUND = \"background\" as const;\n\n/**\n * Enum value \"created\" for attribute {@link ATTR_ANDROID_APP_STATE}.\n *\n * Any time before Activity.onResume() or, if the app has no Activity, Context.startService() has been called in the app for the first time.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ANDROID_APP_STATE_VALUE_CREATED = \"created\" as const;\n\n/**\n * Enum value \"foreground\" for attribute {@link ATTR_ANDROID_APP_STATE}.\n *\n * Any time after Activity.onResume() or, if the app has no Activity, Context.startService() has been called when the app was in either the created or background states.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ANDROID_APP_STATE_VALUE_FOREGROUND = \"foreground\" as const;\n\n/**\n * Uniquely identifies the framework API revision offered by a version (`os.version`) of the android operating system. More information can be found in the [Android API levels documentation](https://developer.android.com/guide/topics/manifest/uses-sdk-element#ApiLevels).\n *\n * @example 33\n * @example 32\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ANDROID_OS_API_LEVEL = 'android.os.api_level' as const;\n\n/**\n * Deprecated. Use `android.app.state` attribute instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `android.app.state`.\n */\nexport const ATTR_ANDROID_STATE = 'android.state' as const;\n\n/**\n * Enum value \"background\" for attribute {@link ATTR_ANDROID_STATE}.\n *\n * Any time after Activity.onPause() or, if the app has no Activity, Context.stopService() has been called when the app was in the foreground state.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ANDROID_STATE_VALUE_BACKGROUND = \"background\" as const;\n\n/**\n * Enum value \"created\" for attribute {@link ATTR_ANDROID_STATE}.\n *\n * Any time before Activity.onResume() or, if the app has no Activity, Context.startService() has been called in the app for the first time.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ANDROID_STATE_VALUE_CREATED = \"created\" as const;\n\n/**\n * Enum value \"foreground\" for attribute {@link ATTR_ANDROID_STATE}.\n *\n * Any time after Activity.onResume() or, if the app has no Activity, Context.startService() has been called when the app was in either the created or background states.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ANDROID_STATE_VALUE_FOREGROUND = \"foreground\" as const;\n\n/**\n * Unique identifier for a particular build or compilation of the application.\n *\n * @example 6cff0a7e-cefc-4668-96f5-1273d8b334d0\n * @example 9f2b833506aa6973a92fde9733e6271f\n * @example my-app-1.0.0-code-123\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_APP_BUILD_ID = 'app.build_id' as const;\n\n/**\n * A unique identifier representing the installation of an application on a specific device\n *\n * @example 2ab2916d-a51f-4ac8-80ee-45ac31a28092\n *\n * @note Its value **SHOULD** persist across launches of the same application installation, including through application upgrades.\n * It **SHOULD** change if the application is uninstalled or if all applications of the vendor are uninstalled.\n * Additionally, users might be able to reset this value (e.g. by clearing application data).\n * If an app is installed multiple times on the same device (e.g. in different accounts on Android), each `app.installation.id` **SHOULD** have a different value.\n * If multiple OpenTelemetry SDKs are used within the same application, they **SHOULD** use the same value for `app.installation.id`.\n * Hardware IDs (e.g. serial number, IMEI, MAC address) **MUST NOT** be used as the `app.installation.id`.\n *\n * For iOS, this value **SHOULD** be equal to the [vendor identifier](https://developer.apple.com/documentation/uikit/uidevice/identifierforvendor).\n *\n * For Android, examples of `app.installation.id` implementations include:\n *\n * - [Firebase Installation ID](https://firebase.google.com/docs/projects/manage-installations).\n * - A globally unique UUID which is persisted across sessions in your application.\n * - [App set ID](https://developer.android.com/identity/app-set-id).\n * - [`Settings.getString(Settings.Secure.ANDROID_ID)`](https://developer.android.com/reference/android/provider/Settings.Secure#ANDROID_ID).\n *\n * More information about Android identifier best practices can be found in the [Android user data IDs guide](https://developer.android.com/training/articles/user-data-ids).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_APP_INSTALLATION_ID = 'app.installation.id' as const;\n\n/**\n * A number of frame renders that experienced jank.\n *\n * @example 9\n * @example 42\n *\n * @note Depending on platform limitations, the value provided **MAY** be approximation.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_APP_JANK_FRAME_COUNT = 'app.jank.frame_count' as const;\n\n/**\n * The time period, in seconds, for which this jank is being reported.\n *\n * @example 1.0\n * @example 5.0\n * @example 10.24\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_APP_JANK_PERIOD = 'app.jank.period' as const;\n\n/**\n * The minimum rendering threshold for this jank, in seconds.\n *\n * @example 0.016\n * @example 0.7\n * @example 1.024\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_APP_JANK_THRESHOLD = 'app.jank.threshold' as const;\n\n/**\n * The x (horizontal) coordinate of a screen coordinate, in screen pixels.\n *\n * @example 0\n * @example 131\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_APP_SCREEN_COORDINATE_X = 'app.screen.coordinate.x' as const;\n\n/**\n * The y (vertical) component of a screen coordinate, in screen pixels.\n *\n * @example 12\n * @example 99\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_APP_SCREEN_COORDINATE_Y = 'app.screen.coordinate.y' as const;\n\n/**\n * An identifier that uniquely differentiates this screen from other screens in the same application.\n *\n * @example f9bc787d-ff05-48ad-90e1-fca1d46130b3\n * @example com.example.app.MainActivity\n * @example com.example.shop.ProductDetailFragment\n * @example MyApp.ProfileView\n * @example MyApp.ProfileViewController\n *\n * @note A screen represents only the part of the device display drawn by the app. It typically contains multiple widgets or UI components and is larger in scope than individual widgets. Multiple screens can coexist on the same display simultaneously (e.g., split view on tablets).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_APP_SCREEN_ID = 'app.screen.id' as const;\n\n/**\n * The name of an application screen.\n *\n * @example MainActivity\n * @example ProductDetailFragment\n * @example ProfileView\n * @example ProfileViewController\n *\n * @note A screen represents only the part of the device display drawn by the app. It typically contains multiple widgets or UI components and is larger in scope than individual widgets. Multiple screens can coexist on the same display simultaneously (e.g., split view on tablets).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_APP_SCREEN_NAME = 'app.screen.name' as const;\n\n/**\n * An identifier that uniquely differentiates this widget from other widgets in the same application.\n *\n * @example f9bc787d-ff05-48ad-90e1-fca1d46130b3\n * @example submit_order_1829\n *\n * @note A widget is an application component, typically an on-screen visual GUI element.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_APP_WIDGET_ID = 'app.widget.id' as const;\n\n/**\n * The name of an application widget.\n *\n * @example submit\n * @example attack\n * @example Clear Cart\n *\n * @note A widget is an application component, typically an on-screen visual GUI element.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_APP_WIDGET_NAME = 'app.widget.name' as const;\n\n/**\n * The provenance filename of the built attestation which directly relates to the build artifact filename. This filename **SHOULD** accompany the artifact at publish time. See the [SLSA Relationship](https://slsa.dev/spec/v1.0/distributing-provenance#relationship-between-artifacts-and-attestations) specification for more information.\n *\n * @example golang-binary-amd64-v0.1.0.attestation\n * @example docker-image-amd64-v0.1.0.intoto.json1\n * @example release-1.tar.gz.attestation\n * @example file-name-package.tar.gz.intoto.json1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ARTIFACT_ATTESTATION_FILENAME = 'artifact.attestation.filename' as const;\n\n/**\n * The full [hash value (see glossary)](https://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.186-5.pdf), of the built attestation. Some envelopes in the [software attestation space](https://github.com/in-toto/attestation/tree/main/spec) also refer to this as the **digest**.\n *\n * @example 1b31dfcd5b7f9267bf2ff47651df1cfb9147b9e4df1f335accf65b4cda498408\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ARTIFACT_ATTESTATION_HASH = 'artifact.attestation.hash' as const;\n\n/**\n * The id of the build [software attestation](https://slsa.dev/attestation-model).\n *\n * @example 123\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ARTIFACT_ATTESTATION_ID = 'artifact.attestation.id' as const;\n\n/**\n * The human readable file name of the artifact, typically generated during build and release processes. Often includes the package name and version in the file name.\n *\n * @example golang-binary-amd64-v0.1.0\n * @example docker-image-amd64-v0.1.0\n * @example release-1.tar.gz\n * @example file-name-package.tar.gz\n *\n * @note This file name can also act as the [Package Name](https://slsa.dev/spec/v1.0/terminology#package-model)\n * in cases where the package ecosystem maps accordingly.\n * Additionally, the artifact [can be published](https://slsa.dev/spec/v1.0/terminology#software-supply-chain)\n * for others, but that is not a guarantee.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ARTIFACT_FILENAME = 'artifact.filename' as const;\n\n/**\n * The full [hash value (see glossary)](https://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.186-5.pdf), often found in checksum.txt on a release of the artifact and used to verify package integrity.\n *\n * @example 9ff4c52759e2c4ac70b7d517bc7fcdc1cda631ca0045271ddd1b192544f8a3e9\n *\n * @note The specific algorithm used to create the cryptographic hash value is\n * not defined. In situations where an artifact has multiple\n * cryptographic hashes, it is up to the implementer to choose which\n * hash value to set here; this should be the most secure hash algorithm\n * that is suitable for the situation and consistent with the\n * corresponding attestation. The implementer can then provide the other\n * hash values through an additional set of attribute extensions as they\n * deem necessary.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ARTIFACT_HASH = 'artifact.hash' as const;\n\n/**\n * The [Package URL](https://github.com/package-url/purl-spec) of the [package artifact](https://slsa.dev/spec/v1.0/terminology#package-model) provides a standard way to identify and locate the packaged artifact.\n *\n * @example pkg:github/package-url/purl-spec@1209109710924\n * @example pkg:npm/foo@12.12.3\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ARTIFACT_PURL = 'artifact.purl' as const;\n\n/**\n * The version of the artifact.\n *\n * @example v0.1.0\n * @example 1.2.1\n * @example 122691-build\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ARTIFACT_VERSION = 'artifact.version' as const;\n\n/**\n * The result of the authentication operation.\n *\n * @example success\n * @example failure\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_AUTHENTICATION_RESULT = 'aspnetcore.authentication.result' as const;\n\n/**\n * Enum value \"failure\" for attribute {@link ATTR_ASPNETCORE_AUTHENTICATION_RESULT}.\n *\n * Authentication failed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_AUTHENTICATION_RESULT_VALUE_FAILURE = \"failure\" as const;\n\n/**\n * Enum value \"none\" for attribute {@link ATTR_ASPNETCORE_AUTHENTICATION_RESULT}.\n *\n * No authentication information returned.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_AUTHENTICATION_RESULT_VALUE_NONE = \"none\" as const;\n\n/**\n * Enum value \"success\" for attribute {@link ATTR_ASPNETCORE_AUTHENTICATION_RESULT}.\n *\n * Authentication was successful.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_AUTHENTICATION_RESULT_VALUE_SUCCESS = \"success\" as const;\n\n/**\n * The identifier that names a particular authentication handler.\n *\n * @example Cookies\n * @example Bearer\n * @example Identity.Application\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_AUTHENTICATION_SCHEME = 'aspnetcore.authentication.scheme' as const;\n\n/**\n * The name of the authorization policy.\n *\n * @example RequireAdminRole\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_AUTHORIZATION_POLICY = 'aspnetcore.authorization.policy' as const;\n\n/**\n * The result of calling the authorization service.\n *\n * @example success\n * @example failure\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_AUTHORIZATION_RESULT = 'aspnetcore.authorization.result' as const;\n\n/**\n * Enum value \"failure\" for attribute {@link ATTR_ASPNETCORE_AUTHORIZATION_RESULT}.\n *\n * Authorization failed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_AUTHORIZATION_RESULT_VALUE_FAILURE = \"failure\" as const;\n\n/**\n * Enum value \"success\" for attribute {@link ATTR_ASPNETCORE_AUTHORIZATION_RESULT}.\n *\n * Authorization was successful.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_AUTHORIZATION_RESULT_VALUE_SUCCESS = \"success\" as const;\n\n/**\n * The error code for a failed identity operation.\n *\n * @example DefaultError\n * @example PasswordMismatch\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_IDENTITY_ERROR_CODE = 'aspnetcore.identity.error_code' as const;\n\n/**\n * The result from checking the password.\n *\n * @example success\n * @example failure\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_IDENTITY_PASSWORD_CHECK_RESULT = 'aspnetcore.identity.password_check_result' as const;\n\n/**\n * Enum value \"failure\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_PASSWORD_CHECK_RESULT}.\n *\n * Password check failed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_PASSWORD_CHECK_RESULT_VALUE_FAILURE = \"failure\" as const;\n\n/**\n * Enum value \"password_missing\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_PASSWORD_CHECK_RESULT}.\n *\n * Password check couldn't proceed because the password was missing from the user.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_PASSWORD_CHECK_RESULT_VALUE_PASSWORD_MISSING = \"password_missing\" as const;\n\n/**\n * Enum value \"success\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_PASSWORD_CHECK_RESULT}.\n *\n * Password check was successful.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_PASSWORD_CHECK_RESULT_VALUE_SUCCESS = \"success\" as const;\n\n/**\n * Enum value \"success_rehash_needed\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_PASSWORD_CHECK_RESULT}.\n *\n * Password check was successful however the password was encoded using a deprecated algorithm and should be rehashed and updated.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_PASSWORD_CHECK_RESULT_VALUE_SUCCESS_REHASH_NEEDED = \"success_rehash_needed\" as const;\n\n/**\n * Enum value \"user_missing\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_PASSWORD_CHECK_RESULT}.\n *\n * Password check couldn't proceed because the user was missing.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_PASSWORD_CHECK_RESULT_VALUE_USER_MISSING = \"user_missing\" as const;\n\n/**\n * The result of the identity operation.\n *\n * @example success\n * @example failure\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_IDENTITY_RESULT = 'aspnetcore.identity.result' as const;\n\n/**\n * Enum value \"failure\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_RESULT}.\n *\n * Identity operation failed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_RESULT_VALUE_FAILURE = \"failure\" as const;\n\n/**\n * Enum value \"success\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_RESULT}.\n *\n * Identity operation was successful.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_RESULT_VALUE_SUCCESS = \"success\" as const;\n\n/**\n * Whether the sign in result was success or failure.\n *\n * @example password\n * @example two_factor\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_IDENTITY_SIGN_IN_RESULT = 'aspnetcore.identity.sign_in.result' as const;\n\n/**\n * Enum value \"failure\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_SIGN_IN_RESULT}.\n *\n * Sign in failed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_SIGN_IN_RESULT_VALUE_FAILURE = \"failure\" as const;\n\n/**\n * Enum value \"locked_out\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_SIGN_IN_RESULT}.\n *\n * User is locked out.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_SIGN_IN_RESULT_VALUE_LOCKED_OUT = \"locked_out\" as const;\n\n/**\n * Enum value \"not_allowed\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_SIGN_IN_RESULT}.\n *\n * User is not allowed to sign in.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_SIGN_IN_RESULT_VALUE_NOT_ALLOWED = \"not_allowed\" as const;\n\n/**\n * Enum value \"requires_two_factor\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_SIGN_IN_RESULT}.\n *\n * User requires two factory authentication to sign in.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_SIGN_IN_RESULT_VALUE_REQUIRES_TWO_FACTOR = \"requires_two_factor\" as const;\n\n/**\n * Enum value \"success\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_SIGN_IN_RESULT}.\n *\n * Sign in was successful.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_SIGN_IN_RESULT_VALUE_SUCCESS = \"success\" as const;\n\n/**\n * The authentication type.\n *\n * @example password\n * @example two_factor\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_IDENTITY_SIGN_IN_TYPE = 'aspnetcore.identity.sign_in.type' as const;\n\n/**\n * Enum value \"external\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_SIGN_IN_TYPE}.\n *\n * Sign in with a previously registered third-party login.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_SIGN_IN_TYPE_VALUE_EXTERNAL = \"external\" as const;\n\n/**\n * Enum value \"passkey\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_SIGN_IN_TYPE}.\n *\n * Sign in with passkey.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_SIGN_IN_TYPE_VALUE_PASSKEY = \"passkey\" as const;\n\n/**\n * Enum value \"password\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_SIGN_IN_TYPE}.\n *\n * Sign in with password.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_SIGN_IN_TYPE_VALUE_PASSWORD = \"password\" as const;\n\n/**\n * Enum value \"two_factor\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_SIGN_IN_TYPE}.\n *\n * Sign in with a two factor provider.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_SIGN_IN_TYPE_VALUE_TWO_FACTOR = \"two_factor\" as const;\n\n/**\n * Enum value \"two_factor_authenticator\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_SIGN_IN_TYPE}.\n *\n * Sign in with two factor authenticator app.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_SIGN_IN_TYPE_VALUE_TWO_FACTOR_AUTHENTICATOR = \"two_factor_authenticator\" as const;\n\n/**\n * Enum value \"two_factor_recovery_code\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_SIGN_IN_TYPE}.\n *\n * Sign in with two factory recovery code.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_SIGN_IN_TYPE_VALUE_TWO_FACTOR_RECOVERY_CODE = \"two_factor_recovery_code\" as const;\n\n/**\n * What the token will be used for.\n *\n * @example success\n * @example failure\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_IDENTITY_TOKEN_PURPOSE = 'aspnetcore.identity.token_purpose' as const;\n\n/**\n * Enum value \"_OTHER\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_TOKEN_PURPOSE}.\n *\n * Any token purpose that the instrumentation has no prior knowledge of.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_TOKEN_PURPOSE_VALUE_OTHER = \"_OTHER\" as const;\n\n/**\n * Enum value \"change_email\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_TOKEN_PURPOSE}.\n *\n * The token is for changing the user email address.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_TOKEN_PURPOSE_VALUE_CHANGE_EMAIL = \"change_email\" as const;\n\n/**\n * Enum value \"change_phone_number\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_TOKEN_PURPOSE}.\n *\n * The token is for changing a user phone number.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_TOKEN_PURPOSE_VALUE_CHANGE_PHONE_NUMBER = \"change_phone_number\" as const;\n\n/**\n * Enum value \"email_confirmation\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_TOKEN_PURPOSE}.\n *\n * The token is for confirming user email address.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_TOKEN_PURPOSE_VALUE_EMAIL_CONFIRMATION = \"email_confirmation\" as const;\n\n/**\n * Enum value \"reset_password\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_TOKEN_PURPOSE}.\n *\n * The token is for resetting a user password.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_TOKEN_PURPOSE_VALUE_RESET_PASSWORD = \"reset_password\" as const;\n\n/**\n * Enum value \"two_factor\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_TOKEN_PURPOSE}.\n *\n * The token is for changing user two factor settings.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_TOKEN_PURPOSE_VALUE_TWO_FACTOR = \"two_factor\" as const;\n\n/**\n * The result of token verification.\n *\n * @example success\n * @example failure\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_IDENTITY_TOKEN_VERIFIED = 'aspnetcore.identity.token_verified' as const;\n\n/**\n * Enum value \"failure\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_TOKEN_VERIFIED}.\n *\n * Token verification failed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_TOKEN_VERIFIED_VALUE_FAILURE = \"failure\" as const;\n\n/**\n * Enum value \"success\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_TOKEN_VERIFIED}.\n *\n * Token verification was successful.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_TOKEN_VERIFIED_VALUE_SUCCESS = \"success\" as const;\n\n/**\n * The user update type.\n *\n * @example update\n * @example user_name\n * @example reset_password\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE = 'aspnetcore.identity.user.update_type' as const;\n\n/**\n * Enum value \"_OTHER\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Any update type that the instrumentation has no prior knowledge of.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_OTHER = \"_OTHER\" as const;\n\n/**\n * Enum value \"access_failed\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user access failure recorded.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_ACCESS_FAILED = \"access_failed\" as const;\n\n/**\n * Enum value \"add_claims\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user claims added.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_ADD_CLAIMS = \"add_claims\" as const;\n\n/**\n * Enum value \"add_login\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user login added.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_ADD_LOGIN = \"add_login\" as const;\n\n/**\n * Enum value \"add_password\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user password added.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_ADD_PASSWORD = \"add_password\" as const;\n\n/**\n * Enum value \"add_to_roles\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user added to roles.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_ADD_TO_ROLES = \"add_to_roles\" as const;\n\n/**\n * Enum value \"change_email\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user email changed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_CHANGE_EMAIL = \"change_email\" as const;\n\n/**\n * Enum value \"change_password\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user password changed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_CHANGE_PASSWORD = \"change_password\" as const;\n\n/**\n * Enum value \"change_phone_number\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user phone number changed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_CHANGE_PHONE_NUMBER = \"change_phone_number\" as const;\n\n/**\n * Enum value \"confirm_email\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user email confirmed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_CONFIRM_EMAIL = \"confirm_email\" as const;\n\n/**\n * Enum value \"generate_new_two_factor_recovery_codes\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user new two-factor recovery codes generated.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_GENERATE_NEW_TWO_FACTOR_RECOVERY_CODES = \"generate_new_two_factor_recovery_codes\" as const;\n\n/**\n * Enum value \"password_rehash\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user password rehashed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_PASSWORD_REHASH = \"password_rehash\" as const;\n\n/**\n * Enum value \"redeem_two_factor_recovery_code\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user two-factor recovery code redeemed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_REDEEM_TWO_FACTOR_RECOVERY_CODE = \"redeem_two_factor_recovery_code\" as const;\n\n/**\n * Enum value \"remove_authentication_token\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user authentication token removed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_REMOVE_AUTHENTICATION_TOKEN = \"remove_authentication_token\" as const;\n\n/**\n * Enum value \"remove_claims\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user claims removed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_REMOVE_CLAIMS = \"remove_claims\" as const;\n\n/**\n * Enum value \"remove_from_roles\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user removed from roles.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_REMOVE_FROM_ROLES = \"remove_from_roles\" as const;\n\n/**\n * Enum value \"remove_login\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user login removed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_REMOVE_LOGIN = \"remove_login\" as const;\n\n/**\n * Enum value \"remove_passkey\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user passkey removed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_REMOVE_PASSKEY = \"remove_passkey\" as const;\n\n/**\n * Enum value \"remove_password\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user password removed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_REMOVE_PASSWORD = \"remove_password\" as const;\n\n/**\n * Enum value \"replace_claim\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user claim replaced.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_REPLACE_CLAIM = \"replace_claim\" as const;\n\n/**\n * Enum value \"reset_access_failed_count\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user access failure count reset.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_RESET_ACCESS_FAILED_COUNT = \"reset_access_failed_count\" as const;\n\n/**\n * Enum value \"reset_authenticator_key\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user authenticator key reset.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_RESET_AUTHENTICATOR_KEY = \"reset_authenticator_key\" as const;\n\n/**\n * Enum value \"reset_password\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user password reset.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_RESET_PASSWORD = \"reset_password\" as const;\n\n/**\n * Enum value \"security_stamp\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user security stamp updated.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_SECURITY_STAMP = \"security_stamp\" as const;\n\n/**\n * Enum value \"set_authentication_token\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user authentication token set.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_SET_AUTHENTICATION_TOKEN = \"set_authentication_token\" as const;\n\n/**\n * Enum value \"set_email\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user email set.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_SET_EMAIL = \"set_email\" as const;\n\n/**\n * Enum value \"set_lockout_enabled\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user lockout enabled or disabled.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_SET_LOCKOUT_ENABLED = \"set_lockout_enabled\" as const;\n\n/**\n * Enum value \"set_lockout_end_date\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user lockout end date set.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_SET_LOCKOUT_END_DATE = \"set_lockout_end_date\" as const;\n\n/**\n * Enum value \"set_passkey\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user passkey set.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_SET_PASSKEY = \"set_passkey\" as const;\n\n/**\n * Enum value \"set_phone_number\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user phone number set.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_SET_PHONE_NUMBER = \"set_phone_number\" as const;\n\n/**\n * Enum value \"set_two_factor_enabled\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user two-factor authentication enabled or disabled.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_SET_TWO_FACTOR_ENABLED = \"set_two_factor_enabled\" as const;\n\n/**\n * Enum value \"update\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user updated.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_UPDATE = \"update\" as const;\n\n/**\n * Enum value \"user_name\" for attribute {@link ATTR_ASPNETCORE_IDENTITY_USER_UPDATE_TYPE}.\n *\n * Identity user name updated.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ASPNETCORE_IDENTITY_USER_UPDATE_TYPE_VALUE_USER_NAME = \"user_name\" as const;\n\n/**\n * The full name of the identity user type.\n *\n * @example Contoso.ContosoUser\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_IDENTITY_USER_TYPE = 'aspnetcore.identity.user_type' as const;\n\n/**\n * The name of the library or subsystem using the memory pool instance.\n *\n * @example kestrel\n * @example iis\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_MEMORY_POOL_OWNER = 'aspnetcore.memory_pool.owner' as const;\n\n/**\n * A flag indicating whether the sign in is persistent.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ASPNETCORE_SIGN_IN_IS_PERSISTENT = 'aspnetcore.sign_in.is_persistent' as const;\n\n/**\n * The unique identifier of the AWS Bedrock Guardrail. A [guardrail](https://docs.aws.amazon.com/bedrock/latest/userguide/guardrails.html) helps safeguard and prevent unwanted behavior from model responses or user messages.\n *\n * @example sgi5gkybzqak\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_BEDROCK_GUARDRAIL_ID = 'aws.bedrock.guardrail.id' as const;\n\n/**\n * The unique identifier of the AWS Bedrock Knowledge base. A [knowledge base](https://docs.aws.amazon.com/bedrock/latest/userguide/knowledge-base.html) is a bank of information that can be queried by models to generate more relevant responses and augment prompts.\n *\n * @example XFWUPB9PAW\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_BEDROCK_KNOWLEDGE_BASE_ID = 'aws.bedrock.knowledge_base.id' as const;\n\n/**\n * The JSON-serialized value of each item in the `AttributeDefinitions` request field.\n *\n * @example [\"{ \"AttributeName\": \"string\", \"AttributeType\": \"string\" }\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_ATTRIBUTE_DEFINITIONS = 'aws.dynamodb.attribute_definitions' as const;\n\n/**\n * The value of the `AttributesToGet` request parameter.\n *\n * @example [\"lives\", \"id\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_ATTRIBUTES_TO_GET = 'aws.dynamodb.attributes_to_get' as const;\n\n/**\n * The value of the `ConsistentRead` request parameter.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_CONSISTENT_READ = 'aws.dynamodb.consistent_read' as const;\n\n/**\n * The JSON-serialized value of each item in the `ConsumedCapacity` response field.\n *\n * @example [\"{ \"CapacityUnits\": number, \"GlobalSecondaryIndexes\": { \"string\" : { \"CapacityUnits\": number, \"ReadCapacityUnits\": number, \"WriteCapacityUnits\": number } }, \"LocalSecondaryIndexes\": { \"string\" : { \"CapacityUnits\": number, \"ReadCapacityUnits\": number, \"WriteCapacityUnits\": number } }, \"ReadCapacityUnits\": number, \"Table\": { \"CapacityUnits\": number, \"ReadCapacityUnits\": number, \"WriteCapacityUnits\": number }, \"TableName\": \"string\", \"WriteCapacityUnits\": number }\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_CONSUMED_CAPACITY = 'aws.dynamodb.consumed_capacity' as const;\n\n/**\n * The value of the `Count` response parameter.\n *\n * @example 10\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_COUNT = 'aws.dynamodb.count' as const;\n\n/**\n * The value of the `ExclusiveStartTableName` request parameter.\n *\n * @example Users\n * @example CatsTable\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_EXCLUSIVE_START_TABLE = 'aws.dynamodb.exclusive_start_table' as const;\n\n/**\n * The JSON-serialized value of each item in the `GlobalSecondaryIndexUpdates` request field.\n *\n * @example [\"{ \"Create\": { \"IndexName\": \"string\", \"KeySchema\": [ { \"AttributeName\": \"string\", \"KeyType\": \"string\" } ], \"Projection\": { \"NonKeyAttributes\": [ \"string\" ], \"ProjectionType\": \"string\" }, \"ProvisionedThroughput\": { \"ReadCapacityUnits\": number, \"WriteCapacityUnits\": number } }\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_GLOBAL_SECONDARY_INDEX_UPDATES = 'aws.dynamodb.global_secondary_index_updates' as const;\n\n/**\n * The JSON-serialized value of each item of the `GlobalSecondaryIndexes` request field\n *\n * @example [\"{ \"IndexName\": \"string\", \"KeySchema\": [ { \"AttributeName\": \"string\", \"KeyType\": \"string\" } ], \"Projection\": { \"NonKeyAttributes\": [ \"string\" ], \"ProjectionType\": \"string\" }, \"ProvisionedThroughput\": { \"ReadCapacityUnits\": number, \"WriteCapacityUnits\": number } }\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_GLOBAL_SECONDARY_INDEXES = 'aws.dynamodb.global_secondary_indexes' as const;\n\n/**\n * The value of the `IndexName` request parameter.\n *\n * @example name_to_group\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_INDEX_NAME = 'aws.dynamodb.index_name' as const;\n\n/**\n * The JSON-serialized value of the `ItemCollectionMetrics` response field.\n *\n * @example { \"string\" : [ { \"ItemCollectionKey\": { \"string\" : { \"B\": blob, \"BOOL\": boolean, \"BS\": [ blob ], \"L\": [ \"AttributeValue\" ], \"M\": { \"string\" : \"AttributeValue\" }, \"N\": \"string\", \"NS\": [ \"string\" ], \"NULL\": boolean, \"S\": \"string\", \"SS\": [ \"string\" ] } }, \"SizeEstimateRangeGB\": [ number ] } ] }\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_ITEM_COLLECTION_METRICS = 'aws.dynamodb.item_collection_metrics' as const;\n\n/**\n * The value of the `Limit` request parameter.\n *\n * @example 10\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_LIMIT = 'aws.dynamodb.limit' as const;\n\n/**\n * The JSON-serialized value of each item of the `LocalSecondaryIndexes` request field.\n *\n * @example [\"{ \"IndexArn\": \"string\", \"IndexName\": \"string\", \"IndexSizeBytes\": number, \"ItemCount\": number, \"KeySchema\": [ { \"AttributeName\": \"string\", \"KeyType\": \"string\" } ], \"Projection\": { \"NonKeyAttributes\": [ \"string\" ], \"ProjectionType\": \"string\" } }\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_LOCAL_SECONDARY_INDEXES = 'aws.dynamodb.local_secondary_indexes' as const;\n\n/**\n * The value of the `ProjectionExpression` request parameter.\n *\n * @example Title\n * @example Title, Price, Color\n * @example Title, Description, RelatedItems, ProductReviews\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_PROJECTION = 'aws.dynamodb.projection' as const;\n\n/**\n * The value of the `ProvisionedThroughput.ReadCapacityUnits` request parameter.\n *\n * @example 1.0\n * @example 2.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_PROVISIONED_READ_CAPACITY = 'aws.dynamodb.provisioned_read_capacity' as const;\n\n/**\n * The value of the `ProvisionedThroughput.WriteCapacityUnits` request parameter.\n *\n * @example 1.0\n * @example 2.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_PROVISIONED_WRITE_CAPACITY = 'aws.dynamodb.provisioned_write_capacity' as const;\n\n/**\n * The value of the `ScanIndexForward` request parameter.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_SCAN_FORWARD = 'aws.dynamodb.scan_forward' as const;\n\n/**\n * The value of the `ScannedCount` response parameter.\n *\n * @example 50\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_SCANNED_COUNT = 'aws.dynamodb.scanned_count' as const;\n\n/**\n * The value of the `Segment` request parameter.\n *\n * @example 10\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_SEGMENT = 'aws.dynamodb.segment' as const;\n\n/**\n * The value of the `Select` request parameter.\n *\n * @example ALL_ATTRIBUTES\n * @example COUNT\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_SELECT = 'aws.dynamodb.select' as const;\n\n/**\n * The number of items in the `TableNames` response parameter.\n *\n * @example 20\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_TABLE_COUNT = 'aws.dynamodb.table_count' as const;\n\n/**\n * The keys in the `RequestItems` object field.\n *\n * @example [\"Users\", \"Cats\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_TABLE_NAMES = 'aws.dynamodb.table_names' as const;\n\n/**\n * The value of the `TotalSegments` request parameter.\n *\n * @example 100\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_DYNAMODB_TOTAL_SEGMENTS = 'aws.dynamodb.total_segments' as const;\n\n/**\n * The ARN of an [ECS cluster](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/clusters.html).\n *\n * @example arn:aws:ecs:us-west-2:123456789123:cluster/my-cluster\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_ECS_CLUSTER_ARN = 'aws.ecs.cluster.arn' as const;\n\n/**\n * The Amazon Resource Name (ARN) of an [ECS container instance](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ECS_instances.html).\n *\n * @example arn:aws:ecs:us-west-1:123456789123:container/32624152-9086-4f0e-acae-1a75b14fe4d9\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_ECS_CONTAINER_ARN = 'aws.ecs.container.arn' as const;\n\n/**\n * The [launch type](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/launch_types.html) for an ECS task.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_ECS_LAUNCHTYPE = 'aws.ecs.launchtype' as const;\n\n/**\n * Enum value \"ec2\" for attribute {@link ATTR_AWS_ECS_LAUNCHTYPE}.\n *\n * Amazon EC2\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const AWS_ECS_LAUNCHTYPE_VALUE_EC2 = \"ec2\" as const;\n\n/**\n * Enum value \"fargate\" for attribute {@link ATTR_AWS_ECS_LAUNCHTYPE}.\n *\n * Amazon Fargate\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const AWS_ECS_LAUNCHTYPE_VALUE_FARGATE = \"fargate\" as const;\n\n/**\n * The ARN of a running [ECS task](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-account-settings.html#ecs-resource-ids).\n *\n * @example arn:aws:ecs:us-west-1:123456789123:task/10838bed-421f-43ef-870a-f43feacbbb5b\n * @example arn:aws:ecs:us-west-1:123456789123:task/my-cluster/task-id/23ebb8ac-c18f-46c6-8bbe-d55d0e37cfbd\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_ECS_TASK_ARN = 'aws.ecs.task.arn' as const;\n\n/**\n * The family name of the [ECS task definition](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_definitions.html) used to create the ECS task.\n *\n * @example opentelemetry-family\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_ECS_TASK_FAMILY = 'aws.ecs.task.family' as const;\n\n/**\n * The ID of a running ECS task. The ID **MUST** be extracted from `task.arn`.\n *\n * @example 10838bed-421f-43ef-870a-f43feacbbb5b\n * @example 23ebb8ac-c18f-46c6-8bbe-d55d0e37cfbd\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_ECS_TASK_ID = 'aws.ecs.task.id' as const;\n\n/**\n * The revision for the task definition used to create the ECS task.\n *\n * @example 8\n * @example 26\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_ECS_TASK_REVISION = 'aws.ecs.task.revision' as const;\n\n/**\n * The ARN of an EKS cluster.\n *\n * @example arn:aws:ecs:us-west-2:123456789123:cluster/my-cluster\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_EKS_CLUSTER_ARN = 'aws.eks.cluster.arn' as const;\n\n/**\n * The AWS extended request ID as returned in the response header `x-amz-id-2`.\n *\n * @example wzHcyEWfmOGDIE5QOhTAqFDoDWP3y8IUvpNINCwL9N4TEHbUw0/gZJ+VZTmCNCWR7fezEN3eCiQ=\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_EXTENDED_REQUEST_ID = 'aws.extended_request_id' as const;\n\n/**\n * The name of the AWS Kinesis [stream](https://docs.aws.amazon.com/streams/latest/dev/introduction.html) the request refers to. Corresponds to the `--stream-name` parameter of the Kinesis [describe-stream](https://docs.aws.amazon.com/cli/latest/reference/kinesis/describe-stream.html) operation.\n *\n * @example some-stream-name\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_KINESIS_STREAM_NAME = 'aws.kinesis.stream_name' as const;\n\n/**\n * The full invoked ARN as provided on the `Context` passed to the function (`Lambda-Runtime-Invoked-Function-Arn` header on the `/runtime/invocation/next` applicable).\n *\n * @example arn:aws:lambda:us-east-1:123456:function:myfunction:myalias\n *\n * @note This may be different from `cloud.resource_id` if an alias is involved.\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_LAMBDA_INVOKED_ARN = 'aws.lambda.invoked_arn' as const;\n\n/**\n * The UUID of the [AWS Lambda EvenSource Mapping](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-lambda-eventsourcemapping.html). An event source is mapped to a lambda function. It's contents are read by Lambda and used to trigger a function. This isn't available in the lambda execution context or the lambda runtime environtment. This is going to be populated by the AWS SDK for each language when that UUID is present. Some of these operations are Create/Delete/Get/List/Update EventSourceMapping.\n *\n * @example 587ad24b-03b9-4413-8202-bbd56b36e5b7\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_LAMBDA_RESOURCE_MAPPING_ID = 'aws.lambda.resource_mapping.id' as const;\n\n/**\n * The Amazon Resource Name(s) (ARN) of the AWS log group(s).\n *\n * @example [\"arn:aws:logs:us-west-1:123456789012:log-group:/aws/my/group:*\"]\n *\n * @note See the [log group ARN format documentation](https://docs.aws.amazon.com/AmazonCloudWatch/latest/logs/iam-access-control-overview-cwl.html#CWL_ARN_Format).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_LOG_GROUP_ARNS = 'aws.log.group.arns' as const;\n\n/**\n * The name(s) of the AWS log group(s) an application is writing to.\n *\n * @example [\"/aws/lambda/my-function\", \"opentelemetry-service\"]\n *\n * @note Multiple log groups must be supported for cases like multi-container applications, where a single application has sidecar containers, and each write to their own log group.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_LOG_GROUP_NAMES = 'aws.log.group.names' as const;\n\n/**\n * The ARN(s) of the AWS log stream(s).\n *\n * @example [\"arn:aws:logs:us-west-1:123456789012:log-group:/aws/my/group:log-stream:logs/main/10838bed-421f-43ef-870a-f43feacbbb5b\"]\n *\n * @note See the [log stream ARN format documentation](https://docs.aws.amazon.com/AmazonCloudWatch/latest/logs/iam-access-control-overview-cwl.html#CWL_ARN_Format). One log group can contain several log streams, so these ARNs necessarily identify both a log group and a log stream.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_LOG_STREAM_ARNS = 'aws.log.stream.arns' as const;\n\n/**\n * The name(s) of the AWS log stream(s) an application is writing to.\n *\n * @example [\"logs/main/10838bed-421f-43ef-870a-f43feacbbb5b\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_LOG_STREAM_NAMES = 'aws.log.stream.names' as const;\n\n/**\n * The AWS request ID as returned in the response headers `x-amzn-requestid`, `x-amzn-request-id` or `x-amz-request-id`.\n *\n * @example 79b9da39-b7ae-508a-a6bc-864b2829c622\n * @example C9ER4AJX75574TDJ\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_REQUEST_ID = 'aws.request_id' as const;\n\n/**\n * The S3 bucket name the request refers to. Corresponds to the `--bucket` parameter of the [S3 API](https://docs.aws.amazon.com/cli/latest/reference/s3api/index.html) operations.\n *\n * @example some-bucket-name\n *\n * @note The `bucket` attribute is applicable to all S3 operations that reference a bucket, i.e. that require the bucket name as a mandatory parameter.\n * This applies to almost all S3 operations except `list-buckets`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_S3_BUCKET = 'aws.s3.bucket' as const;\n\n/**\n * The source object (in the form `bucket`/`key`) for the copy operation.\n *\n * @example someFile.yml\n *\n * @note The `copy_source` attribute applies to S3 copy operations and corresponds to the `--copy-source` parameter\n * of the [copy-object operation within the S3 API](https://docs.aws.amazon.com/cli/latest/reference/s3api/copy-object.html).\n * This applies in particular to the following operations:\n *\n * - [copy-object](https://docs.aws.amazon.com/cli/latest/reference/s3api/copy-object.html)\n * - [upload-part-copy](https://docs.aws.amazon.com/cli/latest/reference/s3api/upload-part-copy.html)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_S3_COPY_SOURCE = 'aws.s3.copy_source' as const;\n\n/**\n * The delete request container that specifies the objects to be deleted.\n *\n * @example Objects=[{Key=string,VersionId=string},{Key=string,VersionId=string}],Quiet=boolean\n *\n * @note The `delete` attribute is only applicable to the [delete-object](https://docs.aws.amazon.com/cli/latest/reference/s3api/delete-object.html) operation.\n * The `delete` attribute corresponds to the `--delete` parameter of the\n * [delete-objects operation within the S3 API](https://docs.aws.amazon.com/cli/latest/reference/s3api/delete-objects.html).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_S3_DELETE = 'aws.s3.delete' as const;\n\n/**\n * The S3 object key the request refers to. Corresponds to the `--key` parameter of the [S3 API](https://docs.aws.amazon.com/cli/latest/reference/s3api/index.html) operations.\n *\n * @example someFile.yml\n *\n * @note The `key` attribute is applicable to all object-related S3 operations, i.e. that require the object key as a mandatory parameter.\n * This applies in particular to the following operations:\n *\n * - [copy-object](https://docs.aws.amazon.com/cli/latest/reference/s3api/copy-object.html)\n * - [delete-object](https://docs.aws.amazon.com/cli/latest/reference/s3api/delete-object.html)\n * - [get-object](https://docs.aws.amazon.com/cli/latest/reference/s3api/get-object.html)\n * - [head-object](https://docs.aws.amazon.com/cli/latest/reference/s3api/head-object.html)\n * - [put-object](https://docs.aws.amazon.com/cli/latest/reference/s3api/put-object.html)\n * - [restore-object](https://docs.aws.amazon.com/cli/latest/reference/s3api/restore-object.html)\n * - [select-object-content](https://docs.aws.amazon.com/cli/latest/reference/s3api/select-object-content.html)\n * - [abort-multipart-upload](https://docs.aws.amazon.com/cli/latest/reference/s3api/abort-multipart-upload.html)\n * - [complete-multipart-upload](https://docs.aws.amazon.com/cli/latest/reference/s3api/complete-multipart-upload.html)\n * - [create-multipart-upload](https://docs.aws.amazon.com/cli/latest/reference/s3api/create-multipart-upload.html)\n * - [list-parts](https://docs.aws.amazon.com/cli/latest/reference/s3api/list-parts.html)\n * - [upload-part](https://docs.aws.amazon.com/cli/latest/reference/s3api/upload-part.html)\n * - [upload-part-copy](https://docs.aws.amazon.com/cli/latest/reference/s3api/upload-part-copy.html)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_S3_KEY = 'aws.s3.key' as const;\n\n/**\n * The part number of the part being uploaded in a multipart-upload operation. This is a positive integer between 1 and 10,000.\n *\n * @example 3456\n *\n * @note The `part_number` attribute is only applicable to the [upload-part](https://docs.aws.amazon.com/cli/latest/reference/s3api/upload-part.html)\n * and [upload-part-copy](https://docs.aws.amazon.com/cli/latest/reference/s3api/upload-part-copy.html) operations.\n * The `part_number` attribute corresponds to the `--part-number` parameter of the\n * [upload-part operation within the S3 API](https://docs.aws.amazon.com/cli/latest/reference/s3api/upload-part.html).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_S3_PART_NUMBER = 'aws.s3.part_number' as const;\n\n/**\n * Upload ID that identifies the multipart upload.\n *\n * @example dfRtDYWFbkRONycy.Yxwh66Yjlx.cph0gtNBtJ\n *\n * @note The `upload_id` attribute applies to S3 multipart-upload operations and corresponds to the `--upload-id` parameter\n * of the [S3 API](https://docs.aws.amazon.com/cli/latest/reference/s3api/index.html) multipart operations.\n * This applies in particular to the following operations:\n *\n * - [abort-multipart-upload](https://docs.aws.amazon.com/cli/latest/reference/s3api/abort-multipart-upload.html)\n * - [complete-multipart-upload](https://docs.aws.amazon.com/cli/latest/reference/s3api/complete-multipart-upload.html)\n * - [list-parts](https://docs.aws.amazon.com/cli/latest/reference/s3api/list-parts.html)\n * - [upload-part](https://docs.aws.amazon.com/cli/latest/reference/s3api/upload-part.html)\n * - [upload-part-copy](https://docs.aws.amazon.com/cli/latest/reference/s3api/upload-part-copy.html)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_S3_UPLOAD_ID = 'aws.s3.upload_id' as const;\n\n/**\n * The ARN of the Secret stored in the Secrets Mangger\n *\n * @example arn:aws:secretsmanager:us-east-1:123456789012:secret:SecretName-6RandomCharacters\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_SECRETSMANAGER_SECRET_ARN = 'aws.secretsmanager.secret.arn' as const;\n\n/**\n * The ARN of the AWS SNS Topic. An Amazon SNS [topic](https://docs.aws.amazon.com/sns/latest/dg/sns-create-topic.html) is a logical access point that acts as a communication channel.\n *\n * @example arn:aws:sns:us-east-1:123456789012:mystack-mytopic-NZJ5JSMVGFIE\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_SNS_TOPIC_ARN = 'aws.sns.topic.arn' as const;\n\n/**\n * The URL of the AWS SQS Queue. It's a unique identifier for a queue in Amazon Simple Queue Service (SQS) and is used to access the queue and perform actions on it.\n *\n * @example https://sqs.us-east-1.amazonaws.com/123456789012/MyQueue\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_SQS_QUEUE_URL = 'aws.sqs.queue.url' as const;\n\n/**\n * The ARN of the AWS Step Functions Activity.\n *\n * @example arn:aws:states:us-east-1:123456789012:activity:get-greeting\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_STEP_FUNCTIONS_ACTIVITY_ARN = 'aws.step_functions.activity.arn' as const;\n\n/**\n * The ARN of the AWS Step Functions State Machine.\n *\n * @example arn:aws:states:us-east-1:123456789012:stateMachine:myStateMachine:1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AWS_STEP_FUNCTIONS_STATE_MACHINE_ARN = 'aws.step_functions.state_machine.arn' as const;\n\n/**\n * Deprecated, use `azure.resource_provider.namespace` instead.\n *\n * @example Microsoft.Storage\n * @example Microsoft.KeyVault\n * @example Microsoft.ServiceBus\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `azure.resource_provider.namespace`.\n */\nexport const ATTR_AZ_NAMESPACE = 'az.namespace' as const;\n\n/**\n * Deprecated, use `azure.service.request.id` instead.\n *\n * @example 00000000-0000-0000-0000-000000000000\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `azure.service.request.id`.\n */\nexport const ATTR_AZ_SERVICE_REQUEST_ID = 'az.service_request_id' as const;\n\n/**\n * The unique identifier of the client instance.\n *\n * @example 3ba4827d-4422-483f-b59f-85b74211c11d\n * @example storage-client-1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AZURE_CLIENT_ID = 'azure.client.id' as const;\n\n/**\n * Cosmos client connection mode.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AZURE_COSMOSDB_CONNECTION_MODE = 'azure.cosmosdb.connection.mode' as const;\n\n/**\n * Enum value \"direct\" for attribute {@link ATTR_AZURE_COSMOSDB_CONNECTION_MODE}.\n *\n * Direct connection.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const AZURE_COSMOSDB_CONNECTION_MODE_VALUE_DIRECT = \"direct\" as const;\n\n/**\n * Enum value \"gateway\" for attribute {@link ATTR_AZURE_COSMOSDB_CONNECTION_MODE}.\n *\n * Gateway (HTTP) connection.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const AZURE_COSMOSDB_CONNECTION_MODE_VALUE_GATEWAY = \"gateway\" as const;\n\n/**\n * Account or request [consistency level](https://learn.microsoft.com/azure/cosmos-db/consistency-levels).\n *\n * @example Eventual\n * @example ConsistentPrefix\n * @example BoundedStaleness\n * @example Strong\n * @example Session\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AZURE_COSMOSDB_CONSISTENCY_LEVEL = 'azure.cosmosdb.consistency.level' as const;\n\n/**\n * Enum value \"BoundedStaleness\" for attribute {@link ATTR_AZURE_COSMOSDB_CONSISTENCY_LEVEL}.\n *\n * Bounded Staleness\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const AZURE_COSMOSDB_CONSISTENCY_LEVEL_VALUE_BOUNDED_STALENESS = \"BoundedStaleness\" as const;\n\n/**\n * Enum value \"ConsistentPrefix\" for attribute {@link ATTR_AZURE_COSMOSDB_CONSISTENCY_LEVEL}.\n *\n * Consistent Prefix\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const AZURE_COSMOSDB_CONSISTENCY_LEVEL_VALUE_CONSISTENT_PREFIX = \"ConsistentPrefix\" as const;\n\n/**\n * Enum value \"Eventual\" for attribute {@link ATTR_AZURE_COSMOSDB_CONSISTENCY_LEVEL}.\n *\n * Eventual\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const AZURE_COSMOSDB_CONSISTENCY_LEVEL_VALUE_EVENTUAL = \"Eventual\" as const;\n\n/**\n * Enum value \"Session\" for attribute {@link ATTR_AZURE_COSMOSDB_CONSISTENCY_LEVEL}.\n *\n * Session\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const AZURE_COSMOSDB_CONSISTENCY_LEVEL_VALUE_SESSION = \"Session\" as const;\n\n/**\n * Enum value \"Strong\" for attribute {@link ATTR_AZURE_COSMOSDB_CONSISTENCY_LEVEL}.\n *\n * Strong\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const AZURE_COSMOSDB_CONSISTENCY_LEVEL_VALUE_STRONG = \"Strong\" as const;\n\n/**\n * List of regions contacted during operation in the order that they were contacted. If there is more than one region listed, it indicates that the operation was performed on multiple regions i.e. cross-regional call.\n *\n * @example [\"North Central US\", \"Australia East\", \"Australia Southeast\"]\n *\n * @note Region name matches the format of `displayName` in [Azure Location API](https://learn.microsoft.com/rest/api/resources/subscriptions/list-locations)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AZURE_COSMOSDB_OPERATION_CONTACTED_REGIONS = 'azure.cosmosdb.operation.contacted_regions' as const;\n\n/**\n * The number of request units consumed by the operation.\n *\n * @example 46.18\n * @example 1.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AZURE_COSMOSDB_OPERATION_REQUEST_CHARGE = 'azure.cosmosdb.operation.request_charge' as const;\n\n/**\n * Request payload size in bytes.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AZURE_COSMOSDB_REQUEST_BODY_SIZE = 'azure.cosmosdb.request.body.size' as const;\n\n/**\n * Cosmos DB sub status code.\n *\n * @example 1000\n * @example 1002\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AZURE_COSMOSDB_RESPONSE_SUB_STATUS_CODE = 'azure.cosmosdb.response.sub_status_code' as const;\n\n/**\n * [Azure Resource Provider Namespace](https://learn.microsoft.com/azure/azure-resource-manager/management/azure-services-resource-providers) as recognized by the client.\n *\n * @example Microsoft.Storage\n * @example Microsoft.KeyVault\n * @example Microsoft.ServiceBus\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AZURE_RESOURCE_PROVIDER_NAMESPACE = 'azure.resource_provider.namespace' as const;\n\n/**\n * The unique identifier of the service request. It's generated by the Azure service and returned with the response.\n *\n * @example 00000000-0000-0000-0000-000000000000\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_AZURE_SERVICE_REQUEST_ID = 'azure.service.request.id' as const;\n\n/**\n * Array of brand name and version separated by a space\n *\n * @example [\" Not A;Brand 99\", \"Chromium 99\", \"Chrome 99\"]\n *\n * @note This value is intended to be taken from the [UA client hints API](https://wicg.github.io/ua-client-hints/#interface) (`navigator.userAgentData.brands`).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_BROWSER_BRANDS = 'browser.brands' as const;\n\n/**\n * Preferred language of the user using the browser\n *\n * @example en\n * @example en-US\n * @example fr\n * @example fr-FR\n *\n * @note This value is intended to be taken from the Navigator API `navigator.language`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_BROWSER_LANGUAGE = 'browser.language' as const;\n\n/**\n * A boolean that is true if the browser is running on a mobile device\n *\n * @note This value is intended to be taken from the [UA client hints API](https://wicg.github.io/ua-client-hints/#interface) (`navigator.userAgentData.mobile`). If unavailable, this attribute **SHOULD** be left unset.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_BROWSER_MOBILE = 'browser.mobile' as const;\n\n/**\n * The platform on which the browser is running\n *\n * @example Windows\n * @example macOS\n * @example Android\n *\n * @note This value is intended to be taken from the [UA client hints API](https://wicg.github.io/ua-client-hints/#interface) (`navigator.userAgentData.platform`). If unavailable, the legacy `navigator.platform` API **SHOULD NOT** be used instead and this attribute **SHOULD** be left unset in order for the values to be consistent.\n * The list of possible values is defined in the [W3C User-Agent Client Hints specification](https://wicg.github.io/ua-client-hints/#sec-ch-ua-platform). Note that some (but not all) of these values can overlap with values in the [`os.type` and `os.name` attributes](./os.md). However, for consistency, the values in the `browser.platform` attribute should capture the exact value that the user agent provides.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_BROWSER_PLATFORM = 'browser.platform' as const;\n\n/**\n * The consistency level of the query. Based on consistency values from [CQL](https://docs.datastax.com/en/cassandra-oss/3.0/cassandra/dml/dmlConfigConsistency.html).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CASSANDRA_CONSISTENCY_LEVEL = 'cassandra.consistency.level' as const;\n\n/**\n * Enum value \"all\" for attribute {@link ATTR_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * All\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CASSANDRA_CONSISTENCY_LEVEL_VALUE_ALL = \"all\" as const;\n\n/**\n * Enum value \"any\" for attribute {@link ATTR_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * Any\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CASSANDRA_CONSISTENCY_LEVEL_VALUE_ANY = \"any\" as const;\n\n/**\n * Enum value \"each_quorum\" for attribute {@link ATTR_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * Each Quorum\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CASSANDRA_CONSISTENCY_LEVEL_VALUE_EACH_QUORUM = \"each_quorum\" as const;\n\n/**\n * Enum value \"local_one\" for attribute {@link ATTR_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * Local One\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CASSANDRA_CONSISTENCY_LEVEL_VALUE_LOCAL_ONE = \"local_one\" as const;\n\n/**\n * Enum value \"local_quorum\" for attribute {@link ATTR_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * Local Quorum\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CASSANDRA_CONSISTENCY_LEVEL_VALUE_LOCAL_QUORUM = \"local_quorum\" as const;\n\n/**\n * Enum value \"local_serial\" for attribute {@link ATTR_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * Local Serial\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CASSANDRA_CONSISTENCY_LEVEL_VALUE_LOCAL_SERIAL = \"local_serial\" as const;\n\n/**\n * Enum value \"one\" for attribute {@link ATTR_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * One\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CASSANDRA_CONSISTENCY_LEVEL_VALUE_ONE = \"one\" as const;\n\n/**\n * Enum value \"quorum\" for attribute {@link ATTR_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * Quorum\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CASSANDRA_CONSISTENCY_LEVEL_VALUE_QUORUM = \"quorum\" as const;\n\n/**\n * Enum value \"serial\" for attribute {@link ATTR_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * Serial\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CASSANDRA_CONSISTENCY_LEVEL_VALUE_SERIAL = \"serial\" as const;\n\n/**\n * Enum value \"three\" for attribute {@link ATTR_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * Three\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CASSANDRA_CONSISTENCY_LEVEL_VALUE_THREE = \"three\" as const;\n\n/**\n * Enum value \"two\" for attribute {@link ATTR_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * Two\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CASSANDRA_CONSISTENCY_LEVEL_VALUE_TWO = \"two\" as const;\n\n/**\n * The data center of the coordinating node for a query.\n *\n * @example \"us-west-2\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CASSANDRA_COORDINATOR_DC = 'cassandra.coordinator.dc' as const;\n\n/**\n * The ID of the coordinating node for a query.\n *\n * @example \"be13faa2-8574-4d71-926d-27f16cf8a7af\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CASSANDRA_COORDINATOR_ID = 'cassandra.coordinator.id' as const;\n\n/**\n * The fetch size used for paging, i.e. how many rows will be returned at once.\n *\n * @example 5000\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CASSANDRA_PAGE_SIZE = 'cassandra.page.size' as const;\n\n/**\n * Whether or not the query is idempotent.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CASSANDRA_QUERY_IDEMPOTENT = 'cassandra.query.idempotent' as const;\n\n/**\n * The number of times a query was speculatively executed. Not set or `0` if the query was not executed speculatively.\n *\n * @example 0\n * @example 2\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CASSANDRA_SPECULATIVE_EXECUTION_COUNT = 'cassandra.speculative_execution.count' as const;\n\n/**\n * The kind of action a pipeline run is performing.\n *\n * @example BUILD\n * @example RUN\n * @example SYNC\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_PIPELINE_ACTION_NAME = 'cicd.pipeline.action.name' as const;\n\n/**\n * Enum value \"BUILD\" for attribute {@link ATTR_CICD_PIPELINE_ACTION_NAME}.\n *\n * The pipeline run is executing a build.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_ACTION_NAME_VALUE_BUILD = \"BUILD\" as const;\n\n/**\n * Enum value \"RUN\" for attribute {@link ATTR_CICD_PIPELINE_ACTION_NAME}.\n *\n * The pipeline run is executing.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_ACTION_NAME_VALUE_RUN = \"RUN\" as const;\n\n/**\n * Enum value \"SYNC\" for attribute {@link ATTR_CICD_PIPELINE_ACTION_NAME}.\n *\n * The pipeline run is executing a sync.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_ACTION_NAME_VALUE_SYNC = \"SYNC\" as const;\n\n/**\n * The human readable name of the pipeline within a CI/CD system.\n *\n * @example Build and Test\n * @example Lint\n * @example Deploy Go Project\n * @example deploy_to_environment\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_PIPELINE_NAME = 'cicd.pipeline.name' as const;\n\n/**\n * The result of a pipeline run.\n *\n * @example success\n * @example failure\n * @example timeout\n * @example skipped\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_PIPELINE_RESULT = 'cicd.pipeline.result' as const;\n\n/**\n * Enum value \"cancellation\" for attribute {@link ATTR_CICD_PIPELINE_RESULT}.\n *\n * The pipeline run was cancelled, eg. by a user manually cancelling the pipeline run.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_RESULT_VALUE_CANCELLATION = \"cancellation\" as const;\n\n/**\n * Enum value \"error\" for attribute {@link ATTR_CICD_PIPELINE_RESULT}.\n *\n * The pipeline run failed due to an error in the CICD system, eg. due to the worker being killed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_RESULT_VALUE_ERROR = \"error\" as const;\n\n/**\n * Enum value \"failure\" for attribute {@link ATTR_CICD_PIPELINE_RESULT}.\n *\n * The pipeline run did not finish successfully, eg. due to a compile error or a failing test. Such failures are usually detected by non-zero exit codes of the tools executed in the pipeline run.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_RESULT_VALUE_FAILURE = \"failure\" as const;\n\n/**\n * Enum value \"skip\" for attribute {@link ATTR_CICD_PIPELINE_RESULT}.\n *\n * The pipeline run was skipped, eg. due to a precondition not being met.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_RESULT_VALUE_SKIP = \"skip\" as const;\n\n/**\n * Enum value \"success\" for attribute {@link ATTR_CICD_PIPELINE_RESULT}.\n *\n * The pipeline run finished successfully.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_RESULT_VALUE_SUCCESS = \"success\" as const;\n\n/**\n * Enum value \"timeout\" for attribute {@link ATTR_CICD_PIPELINE_RESULT}.\n *\n * A timeout caused the pipeline run to be interrupted.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_RESULT_VALUE_TIMEOUT = \"timeout\" as const;\n\n/**\n * The unique identifier of a pipeline run within a CI/CD system.\n *\n * @example 120912\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_PIPELINE_RUN_ID = 'cicd.pipeline.run.id' as const;\n\n/**\n * The pipeline run goes through these states during its lifecycle.\n *\n * @example pending\n * @example executing\n * @example finalizing\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_PIPELINE_RUN_STATE = 'cicd.pipeline.run.state' as const;\n\n/**\n * Enum value \"executing\" for attribute {@link ATTR_CICD_PIPELINE_RUN_STATE}.\n *\n * The executing state spans the execution of any run tasks (eg. build, test).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_RUN_STATE_VALUE_EXECUTING = \"executing\" as const;\n\n/**\n * Enum value \"finalizing\" for attribute {@link ATTR_CICD_PIPELINE_RUN_STATE}.\n *\n * The finalizing state spans from when the run has finished executing (eg. cleanup of run resources).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_RUN_STATE_VALUE_FINALIZING = \"finalizing\" as const;\n\n/**\n * Enum value \"pending\" for attribute {@link ATTR_CICD_PIPELINE_RUN_STATE}.\n *\n * The run pending state spans from the event triggering the pipeline run until the execution of the run starts (eg. time spent in a queue, provisioning agents, creating run resources).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_RUN_STATE_VALUE_PENDING = \"pending\" as const;\n\n/**\n * The [URL](https://wikipedia.org/wiki/URL) of the pipeline run, providing the complete address in order to locate and identify the pipeline run.\n *\n * @example https://github.com/open-telemetry/semantic-conventions/actions/runs/9753949763?pr=1075\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_PIPELINE_RUN_URL_FULL = 'cicd.pipeline.run.url.full' as const;\n\n/**\n * The human readable name of a task within a pipeline. Task here most closely aligns with a [computing process](https://wikipedia.org/wiki/Pipeline_(computing)) in a pipeline. Other terms for tasks include commands, steps, and procedures.\n *\n * @example Run GoLang Linter\n * @example Go Build\n * @example go-test\n * @example deploy_binary\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_PIPELINE_TASK_NAME = 'cicd.pipeline.task.name' as const;\n\n/**\n * The unique identifier of a task run within a pipeline.\n *\n * @example 12097\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_PIPELINE_TASK_RUN_ID = 'cicd.pipeline.task.run.id' as const;\n\n/**\n * The result of a task run.\n *\n * @example success\n * @example failure\n * @example timeout\n * @example skipped\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_PIPELINE_TASK_RUN_RESULT = 'cicd.pipeline.task.run.result' as const;\n\n/**\n * Enum value \"cancellation\" for attribute {@link ATTR_CICD_PIPELINE_TASK_RUN_RESULT}.\n *\n * The task run was cancelled, eg. by a user manually cancelling the task run.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_TASK_RUN_RESULT_VALUE_CANCELLATION = \"cancellation\" as const;\n\n/**\n * Enum value \"error\" for attribute {@link ATTR_CICD_PIPELINE_TASK_RUN_RESULT}.\n *\n * The task run failed due to an error in the CICD system, eg. due to the worker being killed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_TASK_RUN_RESULT_VALUE_ERROR = \"error\" as const;\n\n/**\n * Enum value \"failure\" for attribute {@link ATTR_CICD_PIPELINE_TASK_RUN_RESULT}.\n *\n * The task run did not finish successfully, eg. due to a compile error or a failing test. Such failures are usually detected by non-zero exit codes of the tools executed in the task run.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_TASK_RUN_RESULT_VALUE_FAILURE = \"failure\" as const;\n\n/**\n * Enum value \"skip\" for attribute {@link ATTR_CICD_PIPELINE_TASK_RUN_RESULT}.\n *\n * The task run was skipped, eg. due to a precondition not being met.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_TASK_RUN_RESULT_VALUE_SKIP = \"skip\" as const;\n\n/**\n * Enum value \"success\" for attribute {@link ATTR_CICD_PIPELINE_TASK_RUN_RESULT}.\n *\n * The task run finished successfully.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_TASK_RUN_RESULT_VALUE_SUCCESS = \"success\" as const;\n\n/**\n * Enum value \"timeout\" for attribute {@link ATTR_CICD_PIPELINE_TASK_RUN_RESULT}.\n *\n * A timeout caused the task run to be interrupted.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_TASK_RUN_RESULT_VALUE_TIMEOUT = \"timeout\" as const;\n\n/**\n * The [URL](https://wikipedia.org/wiki/URL) of the pipeline task run, providing the complete address in order to locate and identify the pipeline task run.\n *\n * @example https://github.com/open-telemetry/semantic-conventions/actions/runs/9753949763/job/26920038674?pr=1075\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_PIPELINE_TASK_RUN_URL_FULL = 'cicd.pipeline.task.run.url.full' as const;\n\n/**\n * The type of the task within a pipeline.\n *\n * @example build\n * @example test\n * @example deploy\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_PIPELINE_TASK_TYPE = 'cicd.pipeline.task.type' as const;\n\n/**\n * Enum value \"build\" for attribute {@link ATTR_CICD_PIPELINE_TASK_TYPE}.\n *\n * build\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_TASK_TYPE_VALUE_BUILD = \"build\" as const;\n\n/**\n * Enum value \"deploy\" for attribute {@link ATTR_CICD_PIPELINE_TASK_TYPE}.\n *\n * deploy\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_TASK_TYPE_VALUE_DEPLOY = \"deploy\" as const;\n\n/**\n * Enum value \"test\" for attribute {@link ATTR_CICD_PIPELINE_TASK_TYPE}.\n *\n * test\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_PIPELINE_TASK_TYPE_VALUE_TEST = \"test\" as const;\n\n/**\n * The name of a component of the CICD system.\n *\n * @example controller\n * @example scheduler\n * @example agent\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_SYSTEM_COMPONENT = 'cicd.system.component' as const;\n\n/**\n * The unique identifier of a worker within a CICD system.\n *\n * @example abc123\n * @example 10.0.1.2\n * @example controller\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_WORKER_ID = 'cicd.worker.id' as const;\n\n/**\n * The name of a worker within a CICD system.\n *\n * @example agent-abc\n * @example controller\n * @example Ubuntu LTS\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_WORKER_NAME = 'cicd.worker.name' as const;\n\n/**\n * The state of a CICD worker / agent.\n *\n * @example idle\n * @example busy\n * @example down\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_WORKER_STATE = 'cicd.worker.state' as const;\n\n/**\n * Enum value \"available\" for attribute {@link ATTR_CICD_WORKER_STATE}.\n *\n * The worker is not performing work for the CICD system. It is available to the CICD system to perform work on (online / idle).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_WORKER_STATE_VALUE_AVAILABLE = \"available\" as const;\n\n/**\n * Enum value \"busy\" for attribute {@link ATTR_CICD_WORKER_STATE}.\n *\n * The worker is performing work for the CICD system.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_WORKER_STATE_VALUE_BUSY = \"busy\" as const;\n\n/**\n * Enum value \"offline\" for attribute {@link ATTR_CICD_WORKER_STATE}.\n *\n * The worker is not available to the CICD system (disconnected / down).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CICD_WORKER_STATE_VALUE_OFFLINE = \"offline\" as const;\n\n/**\n * The [URL](https://wikipedia.org/wiki/URL) of the worker, providing the complete address in order to locate and identify the worker.\n *\n * @example https://cicd.example.org/worker/abc123\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CICD_WORKER_URL_FULL = 'cicd.worker.url.full' as const;\n\n/**\n * The cloud account ID the resource is assigned to.\n *\n * @example 111111111111\n * @example opentelemetry\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUD_ACCOUNT_ID = 'cloud.account.id' as const;\n\n/**\n * Cloud regions often have multiple, isolated locations known as zones to increase availability. Availability zone represents the zone where the resource is running.\n *\n * @example us-east-1c\n *\n * @note Availability zones are called \"zones\" on Alibaba Cloud and Google Cloud.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUD_AVAILABILITY_ZONE = 'cloud.availability_zone' as const;\n\n/**\n * The cloud platform in use.\n *\n * @note The prefix of the service **SHOULD** match the one specified in `cloud.provider`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUD_PLATFORM = 'cloud.platform' as const;\n\n/**\n * Enum value \"akamai_cloud.compute\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Akamai Cloud Compute\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AKAMAI_CLOUD_COMPUTE = \"akamai_cloud.compute\" as const;\n\n/**\n * Enum value \"alibaba_cloud_ecs\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Alibaba Cloud Elastic Compute Service\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_ALIBABA_CLOUD_ECS = \"alibaba_cloud_ecs\" as const;\n\n/**\n * Enum value \"alibaba_cloud_fc\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Alibaba Cloud Function Compute\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_ALIBABA_CLOUD_FC = \"alibaba_cloud_fc\" as const;\n\n/**\n * Enum value \"alibaba_cloud_openshift\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Red Hat OpenShift on Alibaba Cloud\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_ALIBABA_CLOUD_OPENSHIFT = \"alibaba_cloud_openshift\" as const;\n\n/**\n * Enum value \"aws_app_runner\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * AWS App Runner\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AWS_APP_RUNNER = \"aws_app_runner\" as const;\n\n/**\n * Enum value \"aws_ec2\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * AWS Elastic Compute Cloud\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AWS_EC2 = \"aws_ec2\" as const;\n\n/**\n * Enum value \"aws_ecs\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * AWS Elastic Container Service\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AWS_ECS = \"aws_ecs\" as const;\n\n/**\n * Enum value \"aws_eks\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * AWS Elastic Kubernetes Service\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AWS_EKS = \"aws_eks\" as const;\n\n/**\n * Enum value \"aws_elastic_beanstalk\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * AWS Elastic Beanstalk\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AWS_ELASTIC_BEANSTALK = \"aws_elastic_beanstalk\" as const;\n\n/**\n * Enum value \"aws_lambda\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * AWS Lambda\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AWS_LAMBDA = \"aws_lambda\" as const;\n\n/**\n * Enum value \"aws_openshift\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Red Hat OpenShift on AWS (ROSA)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AWS_OPENSHIFT = \"aws_openshift\" as const;\n\n/**\n * Enum value \"azure.aks\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Azure Kubernetes Service\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AZURE_AKS = \"azure.aks\" as const;\n\n/**\n * Enum value \"azure.app_service\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Azure App Service\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AZURE_APP_SERVICE = \"azure.app_service\" as const;\n\n/**\n * Enum value \"azure.container_apps\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Azure Container Apps\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AZURE_CONTAINER_APPS = \"azure.container_apps\" as const;\n\n/**\n * Enum value \"azure.container_instances\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Azure Container Instances\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AZURE_CONTAINER_INSTANCES = \"azure.container_instances\" as const;\n\n/**\n * Enum value \"azure.functions\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Azure Functions\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AZURE_FUNCTIONS = \"azure.functions\" as const;\n\n/**\n * Enum value \"azure.openshift\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Azure Red Hat OpenShift\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AZURE_OPENSHIFT = \"azure.openshift\" as const;\n\n/**\n * Enum value \"azure.vm\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Azure Virtual Machines\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_AZURE_VM = \"azure.vm\" as const;\n\n/**\n * Enum value \"gcp.agent_engine\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Google Vertex AI Agent Engine\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_GCP_AGENT_ENGINE = \"gcp.agent_engine\" as const;\n\n/**\n * Enum value \"gcp_app_engine\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Google Cloud App Engine (GAE)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_GCP_APP_ENGINE = \"gcp_app_engine\" as const;\n\n/**\n * Enum value \"gcp_bare_metal_solution\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Google Bare Metal Solution (BMS)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_GCP_BARE_METAL_SOLUTION = \"gcp_bare_metal_solution\" as const;\n\n/**\n * Enum value \"gcp_cloud_functions\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Google Cloud Functions (GCF)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_GCP_CLOUD_FUNCTIONS = \"gcp_cloud_functions\" as const;\n\n/**\n * Enum value \"gcp_cloud_run\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Google Cloud Run\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_GCP_CLOUD_RUN = \"gcp_cloud_run\" as const;\n\n/**\n * Enum value \"gcp_compute_engine\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Google Cloud Compute Engine (GCE)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_GCP_COMPUTE_ENGINE = \"gcp_compute_engine\" as const;\n\n/**\n * Enum value \"gcp_kubernetes_engine\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Google Cloud Kubernetes Engine (GKE)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_GCP_KUBERNETES_ENGINE = \"gcp_kubernetes_engine\" as const;\n\n/**\n * Enum value \"gcp_openshift\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Red Hat OpenShift on Google Cloud\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_GCP_OPENSHIFT = \"gcp_openshift\" as const;\n\n/**\n * Enum value \"hetzner.cloud_server\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Server on Hetzner Cloud\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_HETZNER_CLOUD_SERVER = \"hetzner.cloud_server\" as const;\n\n/**\n * Enum value \"ibm_cloud_openshift\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Red Hat OpenShift on IBM Cloud\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_IBM_CLOUD_OPENSHIFT = \"ibm_cloud_openshift\" as const;\n\n/**\n * Enum value \"oracle_cloud_compute\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Compute on Oracle Cloud Infrastructure (OCI)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_ORACLE_CLOUD_COMPUTE = \"oracle_cloud_compute\" as const;\n\n/**\n * Enum value \"oracle_cloud_oke\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Kubernetes Engine (OKE) on Oracle Cloud Infrastructure (OCI)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_ORACLE_CLOUD_OKE = \"oracle_cloud_oke\" as const;\n\n/**\n * Enum value \"tencent_cloud_cvm\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Tencent Cloud Cloud Virtual Machine (CVM)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_TENCENT_CLOUD_CVM = \"tencent_cloud_cvm\" as const;\n\n/**\n * Enum value \"tencent_cloud_eks\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Tencent Cloud Elastic Kubernetes Service (EKS)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_TENCENT_CLOUD_EKS = \"tencent_cloud_eks\" as const;\n\n/**\n * Enum value \"tencent_cloud_scf\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Tencent Cloud Serverless Cloud Function (SCF)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_TENCENT_CLOUD_SCF = \"tencent_cloud_scf\" as const;\n\n/**\n * Enum value \"vultr.cloud_compute\" for attribute {@link ATTR_CLOUD_PLATFORM}.\n *\n * Vultr Cloud Compute\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PLATFORM_VALUE_VULTR_CLOUD_COMPUTE = \"vultr.cloud_compute\" as const;\n\n/**\n * Name of the cloud provider.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUD_PROVIDER = 'cloud.provider' as const;\n\n/**\n * Enum value \"akamai_cloud\" for attribute {@link ATTR_CLOUD_PROVIDER}.\n *\n * Akamai Cloud\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PROVIDER_VALUE_AKAMAI_CLOUD = \"akamai_cloud\" as const;\n\n/**\n * Enum value \"alibaba_cloud\" for attribute {@link ATTR_CLOUD_PROVIDER}.\n *\n * Alibaba Cloud\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PROVIDER_VALUE_ALIBABA_CLOUD = \"alibaba_cloud\" as const;\n\n/**\n * Enum value \"aws\" for attribute {@link ATTR_CLOUD_PROVIDER}.\n *\n * Amazon Web Services\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PROVIDER_VALUE_AWS = \"aws\" as const;\n\n/**\n * Enum value \"azure\" for attribute {@link ATTR_CLOUD_PROVIDER}.\n *\n * Microsoft Azure\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PROVIDER_VALUE_AZURE = \"azure\" as const;\n\n/**\n * Enum value \"gcp\" for attribute {@link ATTR_CLOUD_PROVIDER}.\n *\n * Google Cloud Platform\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PROVIDER_VALUE_GCP = \"gcp\" as const;\n\n/**\n * Enum value \"heroku\" for attribute {@link ATTR_CLOUD_PROVIDER}.\n *\n * Heroku Platform as a Service\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PROVIDER_VALUE_HEROKU = \"heroku\" as const;\n\n/**\n * Enum value \"hetzner\" for attribute {@link ATTR_CLOUD_PROVIDER}.\n *\n * Hetzner\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PROVIDER_VALUE_HETZNER = \"hetzner\" as const;\n\n/**\n * Enum value \"ibm_cloud\" for attribute {@link ATTR_CLOUD_PROVIDER}.\n *\n * IBM Cloud\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PROVIDER_VALUE_IBM_CLOUD = \"ibm_cloud\" as const;\n\n/**\n * Enum value \"oracle_cloud\" for attribute {@link ATTR_CLOUD_PROVIDER}.\n *\n * Oracle Cloud Infrastructure (OCI)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PROVIDER_VALUE_ORACLE_CLOUD = \"oracle_cloud\" as const;\n\n/**\n * Enum value \"tencent_cloud\" for attribute {@link ATTR_CLOUD_PROVIDER}.\n *\n * Tencent Cloud\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PROVIDER_VALUE_TENCENT_CLOUD = \"tencent_cloud\" as const;\n\n/**\n * Enum value \"vultr\" for attribute {@link ATTR_CLOUD_PROVIDER}.\n *\n * Vultr\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CLOUD_PROVIDER_VALUE_VULTR = \"vultr\" as const;\n\n/**\n * The geographical region within a cloud provider. When associated with a resource, this attribute specifies the region where the resource operates. When calling services or APIs deployed on a cloud, this attribute identifies the region where the called destination is deployed.\n *\n * @example us-central1\n * @example us-east-1\n *\n * @note Refer to your provider's docs to see the available regions, for example [Alibaba Cloud regions](https://www.alibabacloud.com/help/doc-detail/40654.htm), [AWS regions](https://aws.amazon.com/about-aws/global-infrastructure/regions_az/), [Azure regions](https://azure.microsoft.com/global-infrastructure/geographies/), [Google Cloud regions](https://cloud.google.com/about/locations), or [Tencent Cloud regions](https://www.tencentcloud.com/document/product/213/6091).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUD_REGION = 'cloud.region' as const;\n\n/**\n * Cloud provider-specific native identifier of the monitored cloud resource (e.g. an [ARN](https://docs.aws.amazon.com/general/latest/gr/aws-arns-and-namespaces.html) on AWS, a [fully qualified resource ID](https://learn.microsoft.com/rest/api/resources/resources/get-by-id) on Azure, a [full resource name](https://google.aip.dev/122#full-resource-names) on GCP)\n *\n * @example arn:aws:lambda:REGION:ACCOUNT_ID:function:my-function\n * @example //run.googleapis.com/projects/PROJECT_ID/locations/LOCATION_ID/services/SERVICE_ID\n * @example /subscriptions/<SUBSCRIPTION_GUID>/resourceGroups/<RG>/providers/Microsoft.Web/sites/<FUNCAPP>/functions/<FUNC>\n *\n * @note On some cloud providers, it may not be possible to determine the full ID at startup,\n * so it may be necessary to set `cloud.resource_id` as a span attribute instead.\n *\n * The exact value to use for `cloud.resource_id` depends on the cloud provider.\n * The following well-known definitions **MUST** be used if you set this attribute and they apply:\n *\n * - **AWS Lambda:** The function [ARN](https://docs.aws.amazon.com/general/latest/gr/aws-arns-and-namespaces.html).\n * Take care not to use the \"invoked ARN\" directly but replace any\n * [alias suffix](https://docs.aws.amazon.com/lambda/latest/dg/configuration-aliases.html)\n * with the resolved function version, as the same runtime instance may be invocable with\n * multiple different aliases.\n * - **GCP:** The [URI of the resource](https://cloud.google.com/iam/docs/full-resource-names)\n * - **Azure:** The [Fully Qualified Resource ID](https://learn.microsoft.com/rest/api/resources/resources/get-by-id) of the invoked function,\n * *not* the function app, having the form\n * `/subscriptions/<SUBSCRIPTION_GUID>/resourceGroups/<RG>/providers/Microsoft.Web/sites/<FUNCAPP>/functions/<FUNC>`.\n * This means that a span attribute **MUST** be used, as an Azure function app can host multiple functions that would usually share\n * a TracerProvider.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUD_RESOURCE_ID = 'cloud.resource_id' as const;\n\n/**\n * The [event_id](https://github.com/cloudevents/spec/blob/v1.0.2/cloudevents/spec.md#id) uniquely identifies the event.\n *\n * @example 123e4567-e89b-12d3-a456-426614174000\n * @example 0001\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDEVENTS_EVENT_ID = 'cloudevents.event_id' as const;\n\n/**\n * The [source](https://github.com/cloudevents/spec/blob/v1.0.2/cloudevents/spec.md#source-1) identifies the context in which an event happened.\n *\n * @example https://github.com/cloudevents\n * @example /cloudevents/spec/pull/123\n * @example my-service\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDEVENTS_EVENT_SOURCE = 'cloudevents.event_source' as const;\n\n/**\n * The [version of the CloudEvents specification](https://github.com/cloudevents/spec/blob/v1.0.2/cloudevents/spec.md#specversion) which the event uses.\n *\n * @example \"1.0\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDEVENTS_EVENT_SPEC_VERSION = 'cloudevents.event_spec_version' as const;\n\n/**\n * The [subject](https://github.com/cloudevents/spec/blob/v1.0.2/cloudevents/spec.md#subject) of the event in the context of the event producer (identified by source).\n *\n * @example \"mynewfile.jpg\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDEVENTS_EVENT_SUBJECT = 'cloudevents.event_subject' as const;\n\n/**\n * The [event_type](https://github.com/cloudevents/spec/blob/v1.0.2/cloudevents/spec.md#type) contains a value describing the type of event related to the originating occurrence.\n *\n * @example com.github.pull_request.opened\n * @example com.example.object.deleted.v2\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDEVENTS_EVENT_TYPE = 'cloudevents.event_type' as const;\n\n/**\n * The guid of the application.\n *\n * @example 218fc5a9-a5f1-4b54-aa05-46717d0ab26d\n *\n * @note Application instrumentation should use the value from environment\n * variable `VCAP_APPLICATION.application_id`. This is the same value as\n * reported by `cf app <app-name> --guid`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDFOUNDRY_APP_ID = 'cloudfoundry.app.id' as const;\n\n/**\n * The index of the application instance. 0 when just one instance is active.\n *\n * @example 0\n * @example 1\n *\n * @note CloudFoundry defines the `instance_id` in the [Loggregator v2 envelope](https://github.com/cloudfoundry/loggregator-api#v2-envelope).\n * It is used for logs and metrics emitted by CloudFoundry. It is\n * supposed to contain the application instance index for applications\n * deployed on the runtime.\n *\n * Application instrumentation should use the value from environment\n * variable `CF_INSTANCE_INDEX`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDFOUNDRY_APP_INSTANCE_ID = 'cloudfoundry.app.instance.id' as const;\n\n/**\n * The name of the application.\n *\n * @example my-app-name\n *\n * @note Application instrumentation should use the value from environment\n * variable `VCAP_APPLICATION.application_name`. This is the same value\n * as reported by `cf apps`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDFOUNDRY_APP_NAME = 'cloudfoundry.app.name' as const;\n\n/**\n * The guid of the CloudFoundry org the application is running in.\n *\n * @example 218fc5a9-a5f1-4b54-aa05-46717d0ab26d\n *\n * @note Application instrumentation should use the value from environment\n * variable `VCAP_APPLICATION.org_id`. This is the same value as\n * reported by `cf org <org-name> --guid`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDFOUNDRY_ORG_ID = 'cloudfoundry.org.id' as const;\n\n/**\n * The name of the CloudFoundry organization the app is running in.\n *\n * @example my-org-name\n *\n * @note Application instrumentation should use the value from environment\n * variable `VCAP_APPLICATION.org_name`. This is the same value as\n * reported by `cf orgs`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDFOUNDRY_ORG_NAME = 'cloudfoundry.org.name' as const;\n\n/**\n * The UID identifying the process.\n *\n * @example 218fc5a9-a5f1-4b54-aa05-46717d0ab26d\n *\n * @note Application instrumentation should use the value from environment\n * variable `VCAP_APPLICATION.process_id`. It is supposed to be equal to\n * `VCAP_APPLICATION.app_id` for applications deployed to the runtime.\n * For system components, this could be the actual PID.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDFOUNDRY_PROCESS_ID = 'cloudfoundry.process.id' as const;\n\n/**\n * The type of process.\n *\n * @example web\n *\n * @note CloudFoundry applications can consist of multiple jobs. Usually the\n * main process will be of type `web`. There can be additional background\n * tasks or side-cars with different process types.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDFOUNDRY_PROCESS_TYPE = 'cloudfoundry.process.type' as const;\n\n/**\n * The guid of the CloudFoundry space the application is running in.\n *\n * @example 218fc5a9-a5f1-4b54-aa05-46717d0ab26d\n *\n * @note Application instrumentation should use the value from environment\n * variable `VCAP_APPLICATION.space_id`. This is the same value as\n * reported by `cf space <space-name> --guid`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDFOUNDRY_SPACE_ID = 'cloudfoundry.space.id' as const;\n\n/**\n * The name of the CloudFoundry space the application is running in.\n *\n * @example my-space-name\n *\n * @note Application instrumentation should use the value from environment\n * variable `VCAP_APPLICATION.space_name`. This is the same value as\n * reported by `cf spaces`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDFOUNDRY_SPACE_NAME = 'cloudfoundry.space.name' as const;\n\n/**\n * A guid or another name describing the event source.\n *\n * @example cf/gorouter\n *\n * @note CloudFoundry defines the `source_id` in the [Loggregator v2 envelope](https://github.com/cloudfoundry/loggregator-api#v2-envelope).\n * It is used for logs and metrics emitted by CloudFoundry. It is\n * supposed to contain the component name, e.g. \"gorouter\", for\n * CloudFoundry components.\n *\n * When system components are instrumented, values from the\n * [Bosh spec](https://bosh.io/docs/jobs/#properties-spec)\n * should be used. The `system.id` should be set to\n * `spec.deployment/spec.name`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDFOUNDRY_SYSTEM_ID = 'cloudfoundry.system.id' as const;\n\n/**\n * A guid describing the concrete instance of the event source.\n *\n * @example 218fc5a9-a5f1-4b54-aa05-46717d0ab26d\n *\n * @note CloudFoundry defines the `instance_id` in the [Loggregator v2 envelope](https://github.com/cloudfoundry/loggregator-api#v2-envelope).\n * It is used for logs and metrics emitted by CloudFoundry. It is\n * supposed to contain the vm id for CloudFoundry components.\n *\n * When system components are instrumented, values from the\n * [Bosh spec](https://bosh.io/docs/jobs/#properties-spec)\n * should be used. The `system.instance.id` should be set to `spec.id`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CLOUDFOUNDRY_SYSTEM_INSTANCE_ID = 'cloudfoundry.system.instance.id' as const;\n\n/**\n * Deprecated, use `code.column.number`\n *\n * @example 16\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `code.column.number`.\n */\nexport const ATTR_CODE_COLUMN = 'code.column' as const;\n\n/**\n * Deprecated, use `code.file.path` instead\n *\n * @example \"/usr/local/MyApplication/content_root/app/index.php\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `code.file.path`.\n */\nexport const ATTR_CODE_FILEPATH = 'code.filepath' as const;\n\n/**\n * Deprecated, use `code.function.name` instead\n *\n * @example \"serveRequest\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Value should be included in `code.function.name` which is expected to be a fully-qualified name.\n */\nexport const ATTR_CODE_FUNCTION = 'code.function' as const;\n\n/**\n * Deprecated, use `code.line.number` instead\n *\n * @example 42\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `code.line.number`.\n */\nexport const ATTR_CODE_LINENO = 'code.lineno' as const;\n\n/**\n * Deprecated, namespace is now included into `code.function.name`\n *\n * @example \"com.example.MyHttpService\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Value should be included in `code.function.name` which is expected to be a fully-qualified name.\n */\nexport const ATTR_CODE_NAMESPACE = 'code.namespace' as const;\n\n/**\n * The command used to run the container (i.e. the command name).\n *\n * @example otelcontribcol\n *\n * @note If using embedded credentials or sensitive data, it is recommended to remove them to prevent potential leakage.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_COMMAND = 'container.command' as const;\n\n/**\n * All the command arguments (including the command/executable itself) run by the container.\n *\n * @example [\"otelcontribcol\", \"--config\", \"config.yaml\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_COMMAND_ARGS = 'container.command_args' as const;\n\n/**\n * The full command run by the container as a single string representing the full command.\n *\n * @example otelcontribcol --config config.yaml\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_COMMAND_LINE = 'container.command_line' as const;\n\n/**\n * Deprecated, use `cpu.mode` instead.\n *\n * @example user\n * @example kernel\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `cpu.mode`.\n */\nexport const ATTR_CONTAINER_CPU_STATE = 'container.cpu.state' as const;\n\n/**\n * Enum value \"kernel\" for attribute {@link ATTR_CONTAINER_CPU_STATE}.\n *\n * When tasks of the cgroup are in kernel mode (Linux). When all container processes are in kernel mode (Windows).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CONTAINER_CPU_STATE_VALUE_KERNEL = \"kernel\" as const;\n\n/**\n * Enum value \"system\" for attribute {@link ATTR_CONTAINER_CPU_STATE}.\n *\n * When CPU is used by the system (host OS)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CONTAINER_CPU_STATE_VALUE_SYSTEM = \"system\" as const;\n\n/**\n * Enum value \"user\" for attribute {@link ATTR_CONTAINER_CPU_STATE}.\n *\n * When tasks of the cgroup are in user mode (Linux). When all container processes are in user mode (Windows).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CONTAINER_CPU_STATE_VALUE_USER = \"user\" as const;\n\n/**\n * The name of the CSI ([Container Storage Interface](https://github.com/container-storage-interface/spec)) plugin used by the volume.\n *\n * @example pd.csi.storage.gke.io\n *\n * @note This can sometimes be referred to as a \"driver\" in CSI implementations. This should represent the `name` field of the GetPluginInfo RPC.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_CSI_PLUGIN_NAME = 'container.csi.plugin.name' as const;\n\n/**\n * The unique volume ID returned by the CSI ([Container Storage Interface](https://github.com/container-storage-interface/spec)) plugin.\n *\n * @example projects/my-gcp-project/zones/my-gcp-zone/disks/my-gcp-disk\n *\n * @note This can sometimes be referred to as a \"volume handle\" in CSI implementations. This should represent the `Volume.volume_id` field in CSI spec.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_CSI_VOLUME_ID = 'container.csi.volume.id' as const;\n\n/**\n * Container ID. Usually a UUID, as for example used to [identify Docker containers](https://docs.docker.com/engine/containers/run/#container-identification). The UUID might be abbreviated.\n *\n * @example a3bf90e006b2\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_ID = 'container.id' as const;\n\n/**\n * Runtime specific image identifier. Usually a hash algorithm followed by a UUID.\n *\n * @example sha256:19c92d0a00d1b66d897bceaa7319bee0dd38a10a851c60bcec9474aa3f01e50f\n *\n * @note Docker defines a sha256 of the image id; `container.image.id` corresponds to the `Image` field from the Docker container inspect [API](https://docs.docker.com/reference/api/engine/version/v1.52/#tag/Container/operation/ContainerInspect) endpoint.\n * K8s defines a link to the container registry repository with digest `\"imageID\": \"registry.azurecr.io /namespace/service/dockerfile@sha256:bdeabd40c3a8a492eaf9e8e44d0ebbb84bac7ee25ac0cf8a7159d25f62555625\"`.\n * The ID is assigned by the container runtime and can vary in different environments. Consider using `oci.manifest.digest` if it is important to identify the same image in different environments/runtimes.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_IMAGE_ID = 'container.image.id' as const;\n\n/**\n * Name of the image the container was built on.\n *\n * @example gcr.io/opentelemetry/operator\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_IMAGE_NAME = 'container.image.name' as const;\n\n/**\n * Repo digests of the container image as provided by the container runtime.\n *\n * @example [\"example@sha256:afcc7f1ac1b49db317a7196c902e61c6c3c4607d63599ee1a82d702d249a0ccb\", \"internal.registry.example.com:5000/example@sha256:b69959407d21e8a062e0416bf13405bb2b71ed7a84dde4158ebafacfa06f5578\"]\n *\n * @note [Docker](https://docs.docker.com/reference/api/engine/version/v1.52/#tag/Image/operation/ImageInspect) and [CRI](https://github.com/kubernetes/cri-api/blob/c75ef5b473bbe2d0a4fc92f82235efd665ea8e9f/pkg/apis/runtime/v1/api.proto#L1237-L1238) report those under the `RepoDigests` field.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_IMAGE_REPO_DIGESTS = 'container.image.repo_digests' as const;\n\n/**\n * Container image tags. An example can be found in [Docker Image Inspect](https://docs.docker.com/reference/api/engine/version/v1.52/#tag/Image/operation/ImageInspect). Should be only the `<tag>` section of the full name for example from `registry.example.com/my-org/my-image:<tag>`.\n *\n * @example [\"v1.27.1\", \"3.5.7-0\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_IMAGE_TAGS = 'container.image.tags' as const;\n\n/**\n * Container labels, `<key>` being the label name, the value being the label value.\n *\n * @example nginx\n *\n * @note For example, a docker container label `app` with value `nginx` **SHOULD** be recorded as the `container.label.app` attribute with value `\"nginx\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_LABEL = (key: string) => `container.label.${key}`;\n\n/**\n * Deprecated, use `container.label` instead.\n *\n * @example nginx\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `container.label`.\n */\nexport const ATTR_CONTAINER_LABELS = (key: string) => `container.labels.${key}`;\n\n/**\n * Container name used by container runtime.\n *\n * @example opentelemetry-autoconf\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_NAME = 'container.name' as const;\n\n/**\n * The container runtime managing this container.\n *\n * @example docker\n * @example containerd\n * @example rkt\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `container.runtime.name`.\n */\nexport const ATTR_CONTAINER_RUNTIME = 'container.runtime' as const;\n\n/**\n * A description about the runtime which could include, for example details about the CRI/API version being used or other customisations.\n *\n * @example docker://19.3.1 - CRI: 1.22.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_RUNTIME_DESCRIPTION = 'container.runtime.description' as const;\n\n/**\n * The container runtime managing this container.\n *\n * @example docker\n * @example containerd\n * @example rkt\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_RUNTIME_NAME = 'container.runtime.name' as const;\n\n/**\n * The version of the runtime of this process, as returned by the runtime without modification.\n *\n * @example \"1.0.0\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CONTAINER_RUNTIME_VERSION = 'container.runtime.version' as const;\n\n/**\n * The logical CPU number [0..n-1]\n *\n * @example 1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CPU_LOGICAL_NUMBER = 'cpu.logical_number' as const;\n\n/**\n * The mode of the CPU\n *\n * @example user\n * @example system\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CPU_MODE = 'cpu.mode' as const;\n\n/**\n * Enum value \"idle\" for attribute {@link ATTR_CPU_MODE}.\n *\n * Idle\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CPU_MODE_VALUE_IDLE = \"idle\" as const;\n\n/**\n * Enum value \"interrupt\" for attribute {@link ATTR_CPU_MODE}.\n *\n * Interrupt\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CPU_MODE_VALUE_INTERRUPT = \"interrupt\" as const;\n\n/**\n * Enum value \"iowait\" for attribute {@link ATTR_CPU_MODE}.\n *\n * IO Wait\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CPU_MODE_VALUE_IOWAIT = \"iowait\" as const;\n\n/**\n * Enum value \"kernel\" for attribute {@link ATTR_CPU_MODE}.\n *\n * Kernel\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CPU_MODE_VALUE_KERNEL = \"kernel\" as const;\n\n/**\n * Enum value \"nice\" for attribute {@link ATTR_CPU_MODE}.\n *\n * Nice\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CPU_MODE_VALUE_NICE = \"nice\" as const;\n\n/**\n * Enum value \"steal\" for attribute {@link ATTR_CPU_MODE}.\n *\n * Steal\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CPU_MODE_VALUE_STEAL = \"steal\" as const;\n\n/**\n * Enum value \"system\" for attribute {@link ATTR_CPU_MODE}.\n *\n * System\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CPU_MODE_VALUE_SYSTEM = \"system\" as const;\n\n/**\n * Enum value \"user\" for attribute {@link ATTR_CPU_MODE}.\n *\n * User\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CPU_MODE_VALUE_USER = \"user\" as const;\n\n/**\n * Value of the garbage collector collection generation.\n *\n * @example 0\n * @example 1\n * @example 2\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_CPYTHON_GC_GENERATION = 'cpython.gc.generation' as const;\n\n/**\n * Enum value 0 for attribute {@link ATTR_CPYTHON_GC_GENERATION}.\n *\n * Generation 0\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CPYTHON_GC_GENERATION_VALUE_GENERATION_0 = 0 as const;\n\n/**\n * Enum value 1 for attribute {@link ATTR_CPYTHON_GC_GENERATION}.\n *\n * Generation 1\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CPYTHON_GC_GENERATION_VALUE_GENERATION_1 = 1 as const;\n\n/**\n * Enum value 2 for attribute {@link ATTR_CPYTHON_GC_GENERATION}.\n *\n * Generation 2\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const CPYTHON_GC_GENERATION_VALUE_GENERATION_2 = 2 as const;\n\n/**\n * Deprecated, use `cassandra.consistency.level` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `cassandra.consistency.level`.\n */\nexport const ATTR_DB_CASSANDRA_CONSISTENCY_LEVEL = 'db.cassandra.consistency_level' as const;\n\n/**\n * Enum value \"all\" for attribute {@link ATTR_DB_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CASSANDRA_CONSISTENCY_LEVEL_VALUE_ALL = \"all\" as const;\n\n/**\n * Enum value \"any\" for attribute {@link ATTR_DB_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CASSANDRA_CONSISTENCY_LEVEL_VALUE_ANY = \"any\" as const;\n\n/**\n * Enum value \"each_quorum\" for attribute {@link ATTR_DB_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CASSANDRA_CONSISTENCY_LEVEL_VALUE_EACH_QUORUM = \"each_quorum\" as const;\n\n/**\n * Enum value \"local_one\" for attribute {@link ATTR_DB_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CASSANDRA_CONSISTENCY_LEVEL_VALUE_LOCAL_ONE = \"local_one\" as const;\n\n/**\n * Enum value \"local_quorum\" for attribute {@link ATTR_DB_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CASSANDRA_CONSISTENCY_LEVEL_VALUE_LOCAL_QUORUM = \"local_quorum\" as const;\n\n/**\n * Enum value \"local_serial\" for attribute {@link ATTR_DB_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CASSANDRA_CONSISTENCY_LEVEL_VALUE_LOCAL_SERIAL = \"local_serial\" as const;\n\n/**\n * Enum value \"one\" for attribute {@link ATTR_DB_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CASSANDRA_CONSISTENCY_LEVEL_VALUE_ONE = \"one\" as const;\n\n/**\n * Enum value \"quorum\" for attribute {@link ATTR_DB_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CASSANDRA_CONSISTENCY_LEVEL_VALUE_QUORUM = \"quorum\" as const;\n\n/**\n * Enum value \"serial\" for attribute {@link ATTR_DB_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CASSANDRA_CONSISTENCY_LEVEL_VALUE_SERIAL = \"serial\" as const;\n\n/**\n * Enum value \"three\" for attribute {@link ATTR_DB_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CASSANDRA_CONSISTENCY_LEVEL_VALUE_THREE = \"three\" as const;\n\n/**\n * Enum value \"two\" for attribute {@link ATTR_DB_CASSANDRA_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CASSANDRA_CONSISTENCY_LEVEL_VALUE_TWO = \"two\" as const;\n\n/**\n * Deprecated, use `cassandra.coordinator.dc` instead.\n *\n * @example \"us-west-2\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `cassandra.coordinator.dc`.\n */\nexport const ATTR_DB_CASSANDRA_COORDINATOR_DC = 'db.cassandra.coordinator.dc' as const;\n\n/**\n * Deprecated, use `cassandra.coordinator.id` instead.\n *\n * @example \"be13faa2-8574-4d71-926d-27f16cf8a7af\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `cassandra.coordinator.id`.\n */\nexport const ATTR_DB_CASSANDRA_COORDINATOR_ID = 'db.cassandra.coordinator.id' as const;\n\n/**\n * Deprecated, use `cassandra.query.idempotent` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `cassandra.query.idempotent`.\n */\nexport const ATTR_DB_CASSANDRA_IDEMPOTENCE = 'db.cassandra.idempotence' as const;\n\n/**\n * Deprecated, use `cassandra.page.size` instead.\n *\n * @example 5000\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `cassandra.page.size`.\n */\nexport const ATTR_DB_CASSANDRA_PAGE_SIZE = 'db.cassandra.page_size' as const;\n\n/**\n * Deprecated, use `cassandra.speculative_execution.count` instead.\n *\n * @example 0\n * @example 2\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `cassandra.speculative_execution.count`.\n */\nexport const ATTR_DB_CASSANDRA_SPECULATIVE_EXECUTION_COUNT = 'db.cassandra.speculative_execution_count' as const;\n\n/**\n * Deprecated, use `db.collection.name` instead.\n *\n * @example \"mytable\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.collection.name`.\n */\nexport const ATTR_DB_CASSANDRA_TABLE = 'db.cassandra.table' as const;\n\n/**\n * The name of the connection pool; unique within the instrumented application. In case the connection pool implementation doesn't provide a name, instrumentation **SHOULD** use a combination of parameters that would make the name unique, for example, combining attributes `server.address`, `server.port`, and `db.namespace`, formatted as `server.address:server.port/db.namespace`. Instrumentations that generate connection pool name following different patterns **SHOULD** document it.\n *\n * @example myDataSource\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DB_CLIENT_CONNECTION_POOL_NAME = 'db.client.connection.pool.name' as const;\n\n/**\n * The state of a connection in the pool\n *\n * @example idle\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DB_CLIENT_CONNECTION_STATE = 'db.client.connection.state' as const;\n\n/**\n * Enum value \"idle\" for attribute {@link ATTR_DB_CLIENT_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CLIENT_CONNECTION_STATE_VALUE_IDLE = \"idle\" as const;\n\n/**\n * Enum value \"used\" for attribute {@link ATTR_DB_CLIENT_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CLIENT_CONNECTION_STATE_VALUE_USED = \"used\" as const;\n\n/**\n * Deprecated, use `db.client.connection.pool.name` instead.\n *\n * @example myDataSource\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.client.connection.pool.name`.\n */\nexport const ATTR_DB_CLIENT_CONNECTIONS_POOL_NAME = 'db.client.connections.pool.name' as const;\n\n/**\n * Deprecated, use `db.client.connection.state` instead.\n *\n * @example idle\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.client.connection.state`.\n */\nexport const ATTR_DB_CLIENT_CONNECTIONS_STATE = 'db.client.connections.state' as const;\n\n/**\n * Enum value \"idle\" for attribute {@link ATTR_DB_CLIENT_CONNECTIONS_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CLIENT_CONNECTIONS_STATE_VALUE_IDLE = \"idle\" as const;\n\n/**\n * Enum value \"used\" for attribute {@link ATTR_DB_CLIENT_CONNECTIONS_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_CLIENT_CONNECTIONS_STATE_VALUE_USED = \"used\" as const;\n\n/**\n * Deprecated, use `server.address`, `server.port` attributes instead.\n *\n * @example \"Server=(localdb)\\\\v11.0;Integrated Security=true;\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `server.address` and `server.port`.\n */\nexport const ATTR_DB_CONNECTION_STRING = 'db.connection_string' as const;\n\n/**\n * Deprecated, use `azure.client.id` instead.\n *\n * @example \"3ba4827d-4422-483f-b59f-85b74211c11d\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `azure.client.id`.\n */\nexport const ATTR_DB_COSMOSDB_CLIENT_ID = 'db.cosmosdb.client_id' as const;\n\n/**\n * Deprecated, use `azure.cosmosdb.connection.mode` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `azure.cosmosdb.connection.mode`.\n */\nexport const ATTR_DB_COSMOSDB_CONNECTION_MODE = 'db.cosmosdb.connection_mode' as const;\n\n/**\n * Enum value \"direct\" for attribute {@link ATTR_DB_COSMOSDB_CONNECTION_MODE}.\n *\n * Direct connection.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_CONNECTION_MODE_VALUE_DIRECT = \"direct\" as const;\n\n/**\n * Enum value \"gateway\" for attribute {@link ATTR_DB_COSMOSDB_CONNECTION_MODE}.\n *\n * Gateway (HTTP) connection.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_CONNECTION_MODE_VALUE_GATEWAY = \"gateway\" as const;\n\n/**\n * Deprecated, use `cosmosdb.consistency.level` instead.\n *\n * @example Eventual\n * @example ConsistentPrefix\n * @example BoundedStaleness\n * @example Strong\n * @example Session\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `azure.cosmosdb.consistency.level`.\n */\nexport const ATTR_DB_COSMOSDB_CONSISTENCY_LEVEL = 'db.cosmosdb.consistency_level' as const;\n\n/**\n * Enum value \"BoundedStaleness\" for attribute {@link ATTR_DB_COSMOSDB_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_CONSISTENCY_LEVEL_VALUE_BOUNDED_STALENESS = \"BoundedStaleness\" as const;\n\n/**\n * Enum value \"ConsistentPrefix\" for attribute {@link ATTR_DB_COSMOSDB_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_CONSISTENCY_LEVEL_VALUE_CONSISTENT_PREFIX = \"ConsistentPrefix\" as const;\n\n/**\n * Enum value \"Eventual\" for attribute {@link ATTR_DB_COSMOSDB_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_CONSISTENCY_LEVEL_VALUE_EVENTUAL = \"Eventual\" as const;\n\n/**\n * Enum value \"Session\" for attribute {@link ATTR_DB_COSMOSDB_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_CONSISTENCY_LEVEL_VALUE_SESSION = \"Session\" as const;\n\n/**\n * Enum value \"Strong\" for attribute {@link ATTR_DB_COSMOSDB_CONSISTENCY_LEVEL}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_CONSISTENCY_LEVEL_VALUE_STRONG = \"Strong\" as const;\n\n/**\n * Deprecated, use `db.collection.name` instead.\n *\n * @example \"mytable\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.collection.name`.\n */\nexport const ATTR_DB_COSMOSDB_CONTAINER = 'db.cosmosdb.container' as const;\n\n/**\n * Deprecated, no replacement at this time.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Removed, no replacement at this time.\n */\nexport const ATTR_DB_COSMOSDB_OPERATION_TYPE = 'db.cosmosdb.operation_type' as const;\n\n/**\n * Enum value \"batch\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_BATCH = \"batch\" as const;\n\n/**\n * Enum value \"create\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_CREATE = \"create\" as const;\n\n/**\n * Enum value \"delete\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_DELETE = \"delete\" as const;\n\n/**\n * Enum value \"execute\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_EXECUTE = \"execute\" as const;\n\n/**\n * Enum value \"execute_javascript\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_EXECUTE_JAVASCRIPT = \"execute_javascript\" as const;\n\n/**\n * Enum value \"head\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_HEAD = \"head\" as const;\n\n/**\n * Enum value \"head_feed\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_HEAD_FEED = \"head_feed\" as const;\n\n/**\n * Enum value \"invalid\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_INVALID = \"invalid\" as const;\n\n/**\n * Enum value \"patch\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_PATCH = \"patch\" as const;\n\n/**\n * Enum value \"query\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_QUERY = \"query\" as const;\n\n/**\n * Enum value \"query_plan\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_QUERY_PLAN = \"query_plan\" as const;\n\n/**\n * Enum value \"read\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_READ = \"read\" as const;\n\n/**\n * Enum value \"read_feed\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_READ_FEED = \"read_feed\" as const;\n\n/**\n * Enum value \"replace\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_REPLACE = \"replace\" as const;\n\n/**\n * Enum value \"upsert\" for attribute {@link ATTR_DB_COSMOSDB_OPERATION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_COSMOSDB_OPERATION_TYPE_VALUE_UPSERT = \"upsert\" as const;\n\n/**\n * Deprecated, use `azure.cosmosdb.operation.contacted_regions` instead.\n *\n * @example [\"North Central US\", \"Australia East\", \"Australia Southeast\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `azure.cosmosdb.operation.contacted_regions`.\n */\nexport const ATTR_DB_COSMOSDB_REGIONS_CONTACTED = 'db.cosmosdb.regions_contacted' as const;\n\n/**\n * Deprecated, use `azure.cosmosdb.operation.request_charge` instead.\n *\n * @example 46.18\n * @example 1.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `azure.cosmosdb.operation.request_charge`.\n */\nexport const ATTR_DB_COSMOSDB_REQUEST_CHARGE = 'db.cosmosdb.request_charge' as const;\n\n/**\n * Deprecated, use `azure.cosmosdb.request.body.size` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `azure.cosmosdb.request.body.size`.\n */\nexport const ATTR_DB_COSMOSDB_REQUEST_CONTENT_LENGTH = 'db.cosmosdb.request_content_length' as const;\n\n/**\n * Deprecated, use `db.response.status_code` instead.\n *\n * @example 200\n * @example 201\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Use `db.response.status_code` instead.\n */\nexport const ATTR_DB_COSMOSDB_STATUS_CODE = 'db.cosmosdb.status_code' as const;\n\n/**\n * Deprecated, use `azure.cosmosdb.response.sub_status_code` instead.\n *\n * @example 1000\n * @example 1002\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `azure.cosmosdb.response.sub_status_code`.\n */\nexport const ATTR_DB_COSMOSDB_SUB_STATUS_CODE = 'db.cosmosdb.sub_status_code' as const;\n\n/**\n * Deprecated, use `db.namespace` instead.\n *\n * @example e9106fc68e3044f0b1475b04bf4ffd5f\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.namespace`.\n */\nexport const ATTR_DB_ELASTICSEARCH_CLUSTER_NAME = 'db.elasticsearch.cluster.name' as const;\n\n/**\n * Deprecated, use `elasticsearch.node.name` instead.\n *\n * @example instance-0000000001\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `elasticsearch.node.name`.\n */\nexport const ATTR_DB_ELASTICSEARCH_NODE_NAME = 'db.elasticsearch.node.name' as const;\n\n/**\n * Deprecated, use `db.operation.parameter` instead.\n *\n * @example test-index\n * @example 123\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.operation.parameter`.\n */\nexport const ATTR_DB_ELASTICSEARCH_PATH_PARTS = (key: string) => `db.elasticsearch.path_parts.${key}`;\n\n/**\n * Deprecated, no general replacement at this time. For Elasticsearch, use `db.elasticsearch.node.name` instead.\n *\n * @example \"mysql-e26b99z.example.com\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Removed, no general replacement at this time. For Elasticsearch, use `db.elasticsearch.node.name` instead.\n */\nexport const ATTR_DB_INSTANCE_ID = 'db.instance.id' as const;\n\n/**\n * Removed, no replacement at this time.\n *\n * @example org.postgresql.Driver\n * @example com.microsoft.sqlserver.jdbc.SQLServerDriver\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Removed, no replacement at this time.\n */\nexport const ATTR_DB_JDBC_DRIVER_CLASSNAME = 'db.jdbc.driver_classname' as const;\n\n/**\n * Deprecated, use `db.collection.name` instead.\n *\n * @example \"mytable\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.collection.name`.\n */\nexport const ATTR_DB_MONGODB_COLLECTION = 'db.mongodb.collection' as const;\n\n/**\n * Deprecated, SQL Server instance is now populated as a part of `db.namespace` attribute.\n *\n * @example \"MSSQLSERVER\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Removed, no replacement at this time.\n */\nexport const ATTR_DB_MSSQL_INSTANCE_NAME = 'db.mssql.instance_name' as const;\n\n/**\n * Deprecated, use `db.namespace` instead.\n *\n * @example customers\n * @example main\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.namespace`.\n */\nexport const ATTR_DB_NAME = 'db.name' as const;\n\n/**\n * Deprecated, use `db.operation.name` instead.\n *\n * @example findAndModify\n * @example HMSET\n * @example SELECT\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.operation.name`.\n */\nexport const ATTR_DB_OPERATION = 'db.operation' as const;\n\n/**\n * A database operation parameter, with `<key>` being the parameter name, and the attribute value being a string representation of the parameter value.\n *\n * @example someval\n * @example 55\n *\n * @note For example, a client-side maximum number of rows to read from the database\n * **MAY** be recorded as the `db.operation.parameter.max_rows` attribute.\n *\n * `db.query.text` parameters **SHOULD** be captured using `db.query.parameter.<key>`\n * instead of `db.operation.parameter.<key>`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DB_OPERATION_PARAMETER = (key: string) => `db.operation.parameter.${key}`;\n\n/**\n * A database query parameter, with `<key>` being the parameter name, and the attribute value being a string representation of the parameter value.\n *\n * @example someval\n * @example 55\n *\n * @note If a query parameter has no name and instead is referenced only by index,\n * then `<key>` **SHOULD** be the 0-based index.\n *\n * `db.query.parameter.<key>` **SHOULD** match\n * up with the parameterized placeholders present in `db.query.text`.\n *\n * It is **RECOMMENDED** to capture the value as provided by the application\n * without attempting to do any case normalization.\n *\n * `db.query.parameter.<key>` **SHOULD NOT** be captured on batch operations.\n *\n * Examples:\n *\n * - For a query `SELECT * FROM users where username = %s` with the parameter `\"jdoe\"`,\n * the attribute `db.query.parameter.0` **SHOULD** be set to `\"jdoe\"`.\n * - For a query `\"SELECT * FROM users WHERE username = %(userName)s;` with parameter\n * `userName = \"jdoe\"`, the attribute `db.query.parameter.userName` **SHOULD** be set to `\"jdoe\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DB_QUERY_PARAMETER = (key: string) => `db.query.parameter.${key}`;\n\n/**\n * Deprecated, use `db.namespace` instead.\n *\n * @example 0\n * @example 1\n * @example 15\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Uncategorized.\n */\nexport const ATTR_DB_REDIS_DATABASE_INDEX = 'db.redis.database_index' as const;\n\n/**\n * Number of rows returned by the operation.\n *\n * @example 10\n * @example 30\n * @example 1000\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DB_RESPONSE_RETURNED_ROWS = 'db.response.returned_rows' as const;\n\n/**\n * Deprecated, use `db.collection.name` instead.\n *\n * @example \"mytable\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.collection.name`, but only if not extracting the value from `db.query.text`.\n */\nexport const ATTR_DB_SQL_TABLE = 'db.sql.table' as const;\n\n/**\n * The database statement being executed.\n *\n * @example SELECT * FROM wuser_table\n * @example SET mykey \"WuValue\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.query.text`.\n */\nexport const ATTR_DB_STATEMENT = 'db.statement' as const;\n\n/**\n * Deprecated, use `db.system.name` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.system.name`.\n */\nexport const ATTR_DB_SYSTEM = 'db.system' as const;\n\n/**\n * Enum value \"adabas\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Adabas (Adaptable Database System)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_ADABAS = \"adabas\" as const;\n\n/**\n * Enum value \"cache\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Deprecated, use `intersystems_cache` instead.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `intersystems_cache`.\n */\nexport const DB_SYSTEM_VALUE_CACHE = \"cache\" as const;\n\n/**\n * Enum value \"cassandra\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Apache Cassandra\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_CASSANDRA = \"cassandra\" as const;\n\n/**\n * Enum value \"clickhouse\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * ClickHouse\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_CLICKHOUSE = \"clickhouse\" as const;\n\n/**\n * Enum value \"cloudscape\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Deprecated, use `other_sql` instead.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `other_sql`.\n */\nexport const DB_SYSTEM_VALUE_CLOUDSCAPE = \"cloudscape\" as const;\n\n/**\n * Enum value \"cockroachdb\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * CockroachDB\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_COCKROACHDB = \"cockroachdb\" as const;\n\n/**\n * Enum value \"coldfusion\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Deprecated, no replacement at this time.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Obsoleted.\n */\nexport const DB_SYSTEM_VALUE_COLDFUSION = \"coldfusion\" as const;\n\n/**\n * Enum value \"cosmosdb\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Microsoft Azure Cosmos DB\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_COSMOSDB = \"cosmosdb\" as const;\n\n/**\n * Enum value \"couchbase\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Couchbase\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_COUCHBASE = \"couchbase\" as const;\n\n/**\n * Enum value \"couchdb\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * CouchDB\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_COUCHDB = \"couchdb\" as const;\n\n/**\n * Enum value \"db2\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * IBM Db2\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_DB2 = \"db2\" as const;\n\n/**\n * Enum value \"derby\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Apache Derby\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_DERBY = \"derby\" as const;\n\n/**\n * Enum value \"dynamodb\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Amazon DynamoDB\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_DYNAMODB = \"dynamodb\" as const;\n\n/**\n * Enum value \"edb\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * EnterpriseDB\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_EDB = \"edb\" as const;\n\n/**\n * Enum value \"elasticsearch\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Elasticsearch\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_ELASTICSEARCH = \"elasticsearch\" as const;\n\n/**\n * Enum value \"filemaker\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * FileMaker\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_FILEMAKER = \"filemaker\" as const;\n\n/**\n * Enum value \"firebird\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Firebird\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_FIREBIRD = \"firebird\" as const;\n\n/**\n * Enum value \"firstsql\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Deprecated, use `other_sql` instead.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `other_sql`.\n */\nexport const DB_SYSTEM_VALUE_FIRSTSQL = \"firstsql\" as const;\n\n/**\n * Enum value \"geode\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Apache Geode\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_GEODE = \"geode\" as const;\n\n/**\n * Enum value \"h2\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * H2\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_H2 = \"h2\" as const;\n\n/**\n * Enum value \"hanadb\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * SAP HANA\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_HANADB = \"hanadb\" as const;\n\n/**\n * Enum value \"hbase\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Apache HBase\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_HBASE = \"hbase\" as const;\n\n/**\n * Enum value \"hive\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Apache Hive\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_HIVE = \"hive\" as const;\n\n/**\n * Enum value \"hsqldb\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * HyperSQL DataBase\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_HSQLDB = \"hsqldb\" as const;\n\n/**\n * Enum value \"influxdb\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * InfluxDB\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_INFLUXDB = \"influxdb\" as const;\n\n/**\n * Enum value \"informix\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Informix\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_INFORMIX = \"informix\" as const;\n\n/**\n * Enum value \"ingres\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Ingres\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_INGRES = \"ingres\" as const;\n\n/**\n * Enum value \"instantdb\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * InstantDB\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_INSTANTDB = \"instantdb\" as const;\n\n/**\n * Enum value \"interbase\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * InterBase\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_INTERBASE = \"interbase\" as const;\n\n/**\n * Enum value \"intersystems_cache\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * InterSystems Caché\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_INTERSYSTEMS_CACHE = \"intersystems_cache\" as const;\n\n/**\n * Enum value \"mariadb\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * MariaDB\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_MARIADB = \"mariadb\" as const;\n\n/**\n * Enum value \"maxdb\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * SAP MaxDB\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_MAXDB = \"maxdb\" as const;\n\n/**\n * Enum value \"memcached\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Memcached\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_MEMCACHED = \"memcached\" as const;\n\n/**\n * Enum value \"mongodb\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * MongoDB\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_MONGODB = \"mongodb\" as const;\n\n/**\n * Enum value \"mssql\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Microsoft SQL Server\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_MSSQL = \"mssql\" as const;\n\n/**\n * Enum value \"mssqlcompact\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Deprecated, Microsoft SQL Server Compact is discontinued.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `other_sql`.\n */\nexport const DB_SYSTEM_VALUE_MSSQLCOMPACT = \"mssqlcompact\" as const;\n\n/**\n * Enum value \"mysql\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * MySQL\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_MYSQL = \"mysql\" as const;\n\n/**\n * Enum value \"neo4j\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Neo4j\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_NEO4J = \"neo4j\" as const;\n\n/**\n * Enum value \"netezza\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Netezza\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_NETEZZA = \"netezza\" as const;\n\n/**\n * Enum value \"opensearch\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * OpenSearch\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_OPENSEARCH = \"opensearch\" as const;\n\n/**\n * Enum value \"oracle\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Oracle Database\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_ORACLE = \"oracle\" as const;\n\n/**\n * Enum value \"other_sql\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Some other SQL database. Fallback only. See notes.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_OTHER_SQL = \"other_sql\" as const;\n\n/**\n * Enum value \"pervasive\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Pervasive PSQL\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_PERVASIVE = \"pervasive\" as const;\n\n/**\n * Enum value \"pointbase\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * PointBase\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_POINTBASE = \"pointbase\" as const;\n\n/**\n * Enum value \"postgresql\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * PostgreSQL\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_POSTGRESQL = \"postgresql\" as const;\n\n/**\n * Enum value \"progress\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Progress Database\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_PROGRESS = \"progress\" as const;\n\n/**\n * Enum value \"redis\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Redis\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_REDIS = \"redis\" as const;\n\n/**\n * Enum value \"redshift\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Amazon Redshift\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_REDSHIFT = \"redshift\" as const;\n\n/**\n * Enum value \"spanner\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Cloud Spanner\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_SPANNER = \"spanner\" as const;\n\n/**\n * Enum value \"sqlite\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * SQLite\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_SQLITE = \"sqlite\" as const;\n\n/**\n * Enum value \"sybase\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Sybase\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_SYBASE = \"sybase\" as const;\n\n/**\n * Enum value \"teradata\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Teradata\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_TERADATA = \"teradata\" as const;\n\n/**\n * Enum value \"trino\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Trino\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_TRINO = \"trino\" as const;\n\n/**\n * Enum value \"vertica\" for attribute {@link ATTR_DB_SYSTEM}.\n *\n * Vertica\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_VALUE_VERTICA = \"vertica\" as const;\n\n/**\n * Enum value \"actian.ingres\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Actian Ingres](https://www.actian.com/databases/ingres/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_ACTIAN_INGRES = \"actian.ingres\" as const;\n\n/**\n * Enum value \"aws.dynamodb\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Amazon DynamoDB](https://aws.amazon.com/pm/dynamodb/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_AWS_DYNAMODB = \"aws.dynamodb\" as const;\n\n/**\n * Enum value \"aws.redshift\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Amazon Redshift](https://aws.amazon.com/redshift/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_AWS_REDSHIFT = \"aws.redshift\" as const;\n\n/**\n * Enum value \"azure.cosmosdb\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Azure Cosmos DB](https://learn.microsoft.com/azure/cosmos-db)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_AZURE_COSMOSDB = \"azure.cosmosdb\" as const;\n\n/**\n * Enum value \"cassandra\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Apache Cassandra](https://cassandra.apache.org/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_CASSANDRA = \"cassandra\" as const;\n\n/**\n * Enum value \"clickhouse\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [ClickHouse](https://clickhouse.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_CLICKHOUSE = \"clickhouse\" as const;\n\n/**\n * Enum value \"cockroachdb\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [CockroachDB](https://www.cockroachlabs.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_COCKROACHDB = \"cockroachdb\" as const;\n\n/**\n * Enum value \"couchbase\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Couchbase](https://www.couchbase.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_COUCHBASE = \"couchbase\" as const;\n\n/**\n * Enum value \"couchdb\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Apache CouchDB](https://couchdb.apache.org/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_COUCHDB = \"couchdb\" as const;\n\n/**\n * Enum value \"derby\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Apache Derby](https://db.apache.org/derby/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_DERBY = \"derby\" as const;\n\n/**\n * Enum value \"elasticsearch\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Elasticsearch](https://www.elastic.co/elasticsearch)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_ELASTICSEARCH = \"elasticsearch\" as const;\n\n/**\n * Enum value \"firebirdsql\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Firebird](https://www.firebirdsql.org/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_FIREBIRDSQL = \"firebirdsql\" as const;\n\n/**\n * Enum value \"gcp.spanner\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Google Cloud Spanner](https://cloud.google.com/spanner)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_GCP_SPANNER = \"gcp.spanner\" as const;\n\n/**\n * Enum value \"geode\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Apache Geode](https://geode.apache.org/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_GEODE = \"geode\" as const;\n\n/**\n * Enum value \"h2database\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [H2 Database](https://h2database.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_H2DATABASE = \"h2database\" as const;\n\n/**\n * Enum value \"hbase\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Apache HBase](https://hbase.apache.org/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_HBASE = \"hbase\" as const;\n\n/**\n * Enum value \"hive\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Apache Hive](https://hive.apache.org/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_HIVE = \"hive\" as const;\n\n/**\n * Enum value \"hsqldb\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [HyperSQL Database](https://hsqldb.org/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_HSQLDB = \"hsqldb\" as const;\n\n/**\n * Enum value \"ibm.db2\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [IBM Db2](https://www.ibm.com/db2)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_IBM_DB2 = \"ibm.db2\" as const;\n\n/**\n * Enum value \"ibm.informix\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [IBM Informix](https://www.ibm.com/products/informix)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_IBM_INFORMIX = \"ibm.informix\" as const;\n\n/**\n * Enum value \"ibm.netezza\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [IBM Netezza](https://www.ibm.com/products/netezza)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_IBM_NETEZZA = \"ibm.netezza\" as const;\n\n/**\n * Enum value \"influxdb\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [InfluxDB](https://www.influxdata.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_INFLUXDB = \"influxdb\" as const;\n\n/**\n * Enum value \"instantdb\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Instant](https://www.instantdb.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_INSTANTDB = \"instantdb\" as const;\n\n/**\n * Enum value \"intersystems.cache\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [InterSystems Caché](https://www.intersystems.com/products/cache/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_INTERSYSTEMS_CACHE = \"intersystems.cache\" as const;\n\n/**\n * Enum value \"memcached\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Memcached](https://memcached.org/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_MEMCACHED = \"memcached\" as const;\n\n/**\n * Enum value \"mongodb\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [MongoDB](https://www.mongodb.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_MONGODB = \"mongodb\" as const;\n\n/**\n * Enum value \"neo4j\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Neo4j](https://neo4j.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_NEO4J = \"neo4j\" as const;\n\n/**\n * Enum value \"opensearch\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [OpenSearch](https://opensearch.org/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_OPENSEARCH = \"opensearch\" as const;\n\n/**\n * Enum value \"oracle.db\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Oracle Database](https://www.oracle.com/database/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_ORACLE_DB = \"oracle.db\" as const;\n\n/**\n * Enum value \"other_sql\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * Some other SQL database. Fallback only.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_OTHER_SQL = \"other_sql\" as const;\n\n/**\n * Enum value \"redis\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Redis](https://redis.io/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_REDIS = \"redis\" as const;\n\n/**\n * Enum value \"sap.hana\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [SAP HANA](https://www.sap.com/products/technology-platform/hana/what-is-sap-hana.html)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_SAP_HANA = \"sap.hana\" as const;\n\n/**\n * Enum value \"sap.maxdb\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [SAP MaxDB](https://maxdb.sap.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_SAP_MAXDB = \"sap.maxdb\" as const;\n\n/**\n * Enum value \"softwareag.adabas\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Adabas (Adaptable Database System)](https://documentation.softwareag.com/?pf=adabas)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_SOFTWAREAG_ADABAS = \"softwareag.adabas\" as const;\n\n/**\n * Enum value \"sqlite\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [SQLite](https://www.sqlite.org/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_SQLITE = \"sqlite\" as const;\n\n/**\n * Enum value \"teradata\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Teradata](https://www.teradata.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_TERADATA = \"teradata\" as const;\n\n/**\n * Enum value \"trino\" for attribute {@link ATTR_DB_SYSTEM_NAME}.\n *\n * [Trino](https://trino.io/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DB_SYSTEM_NAME_VALUE_TRINO = \"trino\" as const;\n\n/**\n * Deprecated, no replacement at this time.\n *\n * @example readonly_user\n * @example reporting_user\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Removed, no replacement at this time.\n */\nexport const ATTR_DB_USER = 'db.user' as const;\n\n/**\n * Deprecated, use `deployment.environment.name` instead.\n *\n * @example staging\n * @example production\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `deployment.environment.name`.\n */\nexport const ATTR_DEPLOYMENT_ENVIRONMENT = 'deployment.environment' as const;\n\n/**\n * Name of the [deployment environment](https://wikipedia.org/wiki/Deployment_environment) (aka deployment tier).\n *\n * @example staging\n * @example production\n *\n * @note `deployment.environment.name` does not affect the uniqueness constraints defined through\n * the `service.namespace`, `service.name` and `service.instance.id` resource attributes.\n * This implies that resources carrying the following attribute combinations **MUST** be\n * considered to be identifying the same service:\n *\n * - `service.name=frontend`, `deployment.environment.name=production`\n * - `service.name=frontend`, `deployment.environment.name=staging`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DEPLOYMENT_ENVIRONMENT_NAME = 'deployment.environment.name' as const;\n\n/**\n * The id of the deployment.\n *\n * @example 1208\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DEPLOYMENT_ID = 'deployment.id' as const;\n\n/**\n * The name of the deployment.\n *\n * @example deploy my app\n * @example deploy-frontend\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DEPLOYMENT_NAME = 'deployment.name' as const;\n\n/**\n * The status of the deployment.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DEPLOYMENT_STATUS = 'deployment.status' as const;\n\n/**\n * Enum value \"failed\" for attribute {@link ATTR_DEPLOYMENT_STATUS}.\n *\n * failed\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DEPLOYMENT_STATUS_VALUE_FAILED = \"failed\" as const;\n\n/**\n * Enum value \"succeeded\" for attribute {@link ATTR_DEPLOYMENT_STATUS}.\n *\n * succeeded\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DEPLOYMENT_STATUS_VALUE_SUCCEEDED = \"succeeded\" as const;\n\n/**\n * Destination address - domain name if available without reverse DNS lookup; otherwise, IP address or Unix domain socket name.\n *\n * @example destination.example.com\n * @example 10.1.2.80\n * @example /tmp/my.sock\n *\n * @note When observed from the source side, and when communicating through an intermediary, `destination.address` **SHOULD** represent the destination address behind any intermediaries, for example proxies, if it's available.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DESTINATION_ADDRESS = 'destination.address' as const;\n\n/**\n * Destination port number\n *\n * @example 3389\n * @example 2888\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DESTINATION_PORT = 'destination.port' as const;\n\n/**\n * A unique identifier representing the device\n *\n * @example 123456789012345\n * @example 01:23:45:67:89:AB\n *\n * @note Its value **SHOULD** be identical for all apps on a device and it **SHOULD NOT** change if an app is uninstalled and re-installed.\n * However, it might be resettable by the user for all apps on a device.\n * Hardware IDs (e.g. vendor-specific serial number, IMEI or MAC address) **MAY** be used as values.\n *\n * More information about Android identifier best practices can be found in the [Android user data IDs guide](https://developer.android.com/training/articles/user-data-ids).\n *\n * > [!WARNING]> This attribute may contain sensitive (PII) information. Caution should be taken when storing personal data or anything which can identify a user. GDPR and data protection laws may apply,\n * > ensure you do your own due diligence.> Due to these reasons, this identifier is not recommended for consumer applications and will likely result in rejection from both Google Play and App Store.\n * > However, it may be appropriate for specific enterprise scenarios, such as kiosk devices or enterprise-managed devices, with appropriate compliance clearance.\n * > Any instrumentation providing this identifier **> MUST**> implement it as an opt-in feature.> See [`app.installation.id`](/docs/registry/attributes/app.md#app-installation-id)> for a more privacy-preserving alternative.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DEVICE_ID = 'device.id' as const;\n\n/**\n * The name of the device manufacturer\n *\n * @example Apple\n * @example Samsung\n *\n * @note The Android OS provides this field via [Build](https://developer.android.com/reference/android/os/Build#MANUFACTURER). iOS apps **SHOULD** hardcode the value `Apple`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DEVICE_MANUFACTURER = 'device.manufacturer' as const;\n\n/**\n * The model identifier for the device\n *\n * @example iPhone3,4\n * @example SM-G920F\n *\n * @note It's recommended this value represents a machine-readable version of the model identifier rather than the market or consumer-friendly name of the device.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DEVICE_MODEL_IDENTIFIER = 'device.model.identifier' as const;\n\n/**\n * The marketing name for the device model\n *\n * @example iPhone 6s Plus\n * @example Samsung Galaxy S6\n *\n * @note It's recommended this value represents a human-readable version of the device model rather than a machine-readable alternative.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DEVICE_MODEL_NAME = 'device.model.name' as const;\n\n/**\n * The disk IO operation direction.\n *\n * @example read\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DISK_IO_DIRECTION = 'disk.io.direction' as const;\n\n/**\n * Enum value \"read\" for attribute {@link ATTR_DISK_IO_DIRECTION}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DISK_IO_DIRECTION_VALUE_READ = \"read\" as const;\n\n/**\n * Enum value \"write\" for attribute {@link ATTR_DISK_IO_DIRECTION}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const DISK_IO_DIRECTION_VALUE_WRITE = \"write\" as const;\n\n/**\n * The list of IPv4 or IPv6 addresses resolved during DNS lookup.\n *\n * @example [\"10.0.0.1\", \"2001:0db8:85a3:0000:0000:8a2e:0370:7334\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DNS_ANSWERS = 'dns.answers' as const;\n\n/**\n * The name being queried.\n *\n * @example www.example.com\n * @example opentelemetry.io\n *\n * @note The name represents the queried domain name as it appears in the DNS query without any additional normalization.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_DNS_QUESTION_NAME = 'dns.question.name' as const;\n\n/**\n * Represents the human-readable identifier of the node/instance to which a request was routed.\n *\n * @example instance-0000000001\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ELASTICSEARCH_NODE_NAME = 'elasticsearch.node.name' as const;\n\n/**\n * Unique identifier of an end user in the system. It maybe a username, email address, or other identifier.\n *\n * @example username\n *\n * @note Unique identifier of an end user in the system.\n *\n * > [!Warning]\n * > This field contains sensitive (PII) information.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ENDUSER_ID = 'enduser.id' as const;\n\n/**\n * Pseudonymous identifier of an end user. This identifier should be a random value that is not directly linked or associated with the end user's actual identity.\n *\n * @example QdH5CAWJgqVT4rOr0qtumf\n *\n * @note Pseudonymous identifier of an end user.\n *\n * > [!Warning]\n * > This field contains sensitive (linkable PII) information.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ENDUSER_PSEUDO_ID = 'enduser.pseudo.id' as const;\n\n/**\n * Deprecated, use `user.roles` instead.\n *\n * @example \"admin\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Use `user.roles` instead.\n */\nexport const ATTR_ENDUSER_ROLE = 'enduser.role' as const;\n\n/**\n * Deprecated, no replacement at this time.\n *\n * @example \"read:message, write:files\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Removed, no replacement at this time.\n */\nexport const ATTR_ENDUSER_SCOPE = 'enduser.scope' as const;\n\n/**\n * A message providing more detail about an error in human-readable form.\n *\n * @example Unexpected input type: string\n * @example The user has exceeded their storage quota\n *\n * @note `error.message` should provide additional context and detail about an error.\n * It is NOT **RECOMMENDED** to duplicate the value of `error.type` in `error.message`.\n * It is also NOT **RECOMMENDED** to duplicate the value of `exception.message` in `error.message`.\n *\n * `error.message` is NOT **RECOMMENDED** for metrics or spans due to its unbounded cardinality and overlap with span status.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ERROR_MESSAGE = 'error.message' as const;\n\n/**\n * Identifies the class / type of event.\n *\n * @example browser.mouse.click\n * @example device.app.lifecycle\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated The value of this attribute **MUST** now be set as the value of the EventName field on the LogRecord to indicate that the LogRecord represents an Event.\n */\nexport const ATTR_EVENT_NAME = 'event.name' as const;\n\n/**\n * A boolean that is true if the serverless function is executed for the first time (aka cold-start).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_COLDSTART = 'faas.coldstart' as const;\n\n/**\n * A string containing the schedule period as [Cron Expression](https://docs.oracle.com/cd/E12058_01/doc/doc.1014/e12030/cron_expressions.htm).\n *\n * @example \"0/5 * * * ? *\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_CRON = 'faas.cron' as const;\n\n/**\n * The name of the source on which the triggering operation was performed. For example, in Cloud Storage or S3 corresponds to the bucket name, and in Cosmos DB to the database name.\n *\n * @example myBucketName\n * @example myDbName\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_DOCUMENT_COLLECTION = 'faas.document.collection' as const;\n\n/**\n * The document name/table subjected to the operation. For example, in Cloud Storage or S3 is the name of the file, and in Cosmos DB the table name.\n *\n * @example myFile.txt\n * @example myTableName\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_DOCUMENT_NAME = 'faas.document.name' as const;\n\n/**\n * Describes the type of the operation that was performed on the data.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_DOCUMENT_OPERATION = 'faas.document.operation' as const;\n\n/**\n * Enum value \"delete\" for attribute {@link ATTR_FAAS_DOCUMENT_OPERATION}.\n *\n * When an object is deleted.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_DOCUMENT_OPERATION_VALUE_DELETE = \"delete\" as const;\n\n/**\n * Enum value \"edit\" for attribute {@link ATTR_FAAS_DOCUMENT_OPERATION}.\n *\n * When an object is modified.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_DOCUMENT_OPERATION_VALUE_EDIT = \"edit\" as const;\n\n/**\n * Enum value \"insert\" for attribute {@link ATTR_FAAS_DOCUMENT_OPERATION}.\n *\n * When a new object is created.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_DOCUMENT_OPERATION_VALUE_INSERT = \"insert\" as const;\n\n/**\n * A string containing the time when the data was accessed in the [ISO 8601](https://www.iso.org/iso-8601-date-and-time-format.html) format expressed in [UTC](https://www.w3.org/TR/NOTE-datetime).\n *\n * @example \"2020-01-23T13:47:06Z\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_DOCUMENT_TIME = 'faas.document.time' as const;\n\n/**\n * The execution environment ID as a string, that will be potentially reused for other invocations to the same function/function version.\n *\n * @example 2021/06/28/[$LATEST]2f399eb14537447da05ab2a2e39309de\n *\n * @note - **AWS Lambda:** Use the (full) log stream name.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_INSTANCE = 'faas.instance' as const;\n\n/**\n * The invocation ID of the current function invocation.\n *\n * @example \"af9d5aa4-a685-4c5f-a22b-444f80b3cc28\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_INVOCATION_ID = 'faas.invocation_id' as const;\n\n/**\n * The name of the invoked function.\n *\n * @example \"my-function\"\n *\n * @note **SHOULD** be equal to the `faas.name` resource attribute of the invoked function.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_INVOKED_NAME = 'faas.invoked_name' as const;\n\n/**\n * The cloud provider of the invoked function.\n *\n * @note **SHOULD** be equal to the `cloud.provider` resource attribute of the invoked function.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_INVOKED_PROVIDER = 'faas.invoked_provider' as const;\n\n/**\n * Enum value \"alibaba_cloud\" for attribute {@link ATTR_FAAS_INVOKED_PROVIDER}.\n *\n * Alibaba Cloud\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_INVOKED_PROVIDER_VALUE_ALIBABA_CLOUD = \"alibaba_cloud\" as const;\n\n/**\n * Enum value \"aws\" for attribute {@link ATTR_FAAS_INVOKED_PROVIDER}.\n *\n * Amazon Web Services\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_INVOKED_PROVIDER_VALUE_AWS = \"aws\" as const;\n\n/**\n * Enum value \"azure\" for attribute {@link ATTR_FAAS_INVOKED_PROVIDER}.\n *\n * Microsoft Azure\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_INVOKED_PROVIDER_VALUE_AZURE = \"azure\" as const;\n\n/**\n * Enum value \"gcp\" for attribute {@link ATTR_FAAS_INVOKED_PROVIDER}.\n *\n * Google Cloud Platform\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_INVOKED_PROVIDER_VALUE_GCP = \"gcp\" as const;\n\n/**\n * Enum value \"tencent_cloud\" for attribute {@link ATTR_FAAS_INVOKED_PROVIDER}.\n *\n * Tencent Cloud\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_INVOKED_PROVIDER_VALUE_TENCENT_CLOUD = \"tencent_cloud\" as const;\n\n/**\n * The cloud region of the invoked function.\n *\n * @example \"eu-central-1\"\n *\n * @note **SHOULD** be equal to the `cloud.region` resource attribute of the invoked function.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_INVOKED_REGION = 'faas.invoked_region' as const;\n\n/**\n * The amount of memory available to the serverless function converted to Bytes.\n *\n * @example 134217728\n *\n * @note It's recommended to set this attribute since e.g. too little memory can easily stop a Java AWS Lambda function from working correctly. On AWS Lambda, the environment variable `AWS_LAMBDA_FUNCTION_MEMORY_SIZE` provides this information (which must be multiplied by 1,048,576).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_MAX_MEMORY = 'faas.max_memory' as const;\n\n/**\n * The name of the single function that this runtime instance executes.\n *\n * @example my-function\n * @example myazurefunctionapp/some-function-name\n *\n * @note This is the name of the function as configured/deployed on the FaaS\n * platform and is usually different from the name of the callback\n * function (which may be stored in the\n * [`code.namespace`/`code.function.name`](/docs/general/attributes.md#source-code-attributes)\n * span attributes).\n *\n * For some cloud providers, the above definition is ambiguous. The following\n * definition of function name **MUST** be used for this attribute\n * (and consequently the span name) for the listed cloud providers/products:\n *\n * - **Azure:** The full name `<FUNCAPP>/<FUNC>`, i.e., function app name\n * followed by a forward slash followed by the function name (this form\n * can also be seen in the resource JSON for the function).\n * This means that a span attribute **MUST** be used, as an Azure function\n * app can host multiple functions that would usually share\n * a TracerProvider (see also the `cloud.resource_id` attribute).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_NAME = 'faas.name' as const;\n\n/**\n * A string containing the function invocation time in the [ISO 8601](https://www.iso.org/iso-8601-date-and-time-format.html) format expressed in [UTC](https://www.w3.org/TR/NOTE-datetime).\n *\n * @example \"2020-01-23T13:47:06Z\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_TIME = 'faas.time' as const;\n\n/**\n * Type of the trigger which caused this function invocation.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_TRIGGER = 'faas.trigger' as const;\n\n/**\n * Enum value \"datasource\" for attribute {@link ATTR_FAAS_TRIGGER}.\n *\n * A response to some data source operation such as a database or filesystem read/write\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_TRIGGER_VALUE_DATASOURCE = \"datasource\" as const;\n\n/**\n * Enum value \"http\" for attribute {@link ATTR_FAAS_TRIGGER}.\n *\n * To provide an answer to an inbound HTTP request\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_TRIGGER_VALUE_HTTP = \"http\" as const;\n\n/**\n * Enum value \"other\" for attribute {@link ATTR_FAAS_TRIGGER}.\n *\n * If none of the others apply\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_TRIGGER_VALUE_OTHER = \"other\" as const;\n\n/**\n * Enum value \"pubsub\" for attribute {@link ATTR_FAAS_TRIGGER}.\n *\n * A function is set to be executed when messages are sent to a messaging system\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_TRIGGER_VALUE_PUBSUB = \"pubsub\" as const;\n\n/**\n * Enum value \"timer\" for attribute {@link ATTR_FAAS_TRIGGER}.\n *\n * A function is scheduled to be executed regularly\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FAAS_TRIGGER_VALUE_TIMER = \"timer\" as const;\n\n/**\n * The immutable version of the function being executed.\n *\n * @example 26\n * @example pinkfroid-00002\n *\n * @note Depending on the cloud provider and platform, use:\n *\n * - **AWS Lambda:** The [function version](https://docs.aws.amazon.com/lambda/latest/dg/configuration-versions.html)\n * (an integer represented as a decimal string).\n * - **Google Cloud Run (Services):** The [revision](https://cloud.google.com/run/docs/managing/revisions)\n * (i.e., the function name plus the revision suffix).\n * - **Google Cloud Functions:** The value of the\n * [`K_REVISION` environment variable](https://cloud.google.com/run/docs/container-contract#services-env-vars).\n * - **Azure Functions:** Not applicable. Do not set this attribute.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FAAS_VERSION = 'faas.version' as const;\n\n/**\n * The unique identifier for the flag evaluation context. For example, the targeting key.\n *\n * @example 5157782b-2203-4c80-a857-dbbd5e7761db\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FEATURE_FLAG_CONTEXT_ID = 'feature_flag.context.id' as const;\n\n/**\n * Deprecated, use `error.message` instead.\n *\n * @example Flag `header-color` expected type `string` but found type `number`\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `error.message`.\n */\nexport const ATTR_FEATURE_FLAG_EVALUATION_ERROR_MESSAGE = 'feature_flag.evaluation.error.message' as const;\n\n/**\n * Deprecated, use `feature_flag.result.reason` instead.\n *\n * @example static\n * @example targeting_match\n * @example error\n * @example default\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `feature_flag.result.reason`.\n */\nexport const ATTR_FEATURE_FLAG_EVALUATION_REASON = 'feature_flag.evaluation.reason' as const;\n\n/**\n * Enum value \"cached\" for attribute {@link ATTR_FEATURE_FLAG_EVALUATION_REASON}.\n *\n * The resolved value was retrieved from cache.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_EVALUATION_REASON_VALUE_CACHED = \"cached\" as const;\n\n/**\n * Enum value \"default\" for attribute {@link ATTR_FEATURE_FLAG_EVALUATION_REASON}.\n *\n * The resolved value fell back to a pre-configured value (no dynamic evaluation occurred or dynamic evaluation yielded no result).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_EVALUATION_REASON_VALUE_DEFAULT = \"default\" as const;\n\n/**\n * Enum value \"disabled\" for attribute {@link ATTR_FEATURE_FLAG_EVALUATION_REASON}.\n *\n * The resolved value was the result of the flag being disabled in the management system.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_EVALUATION_REASON_VALUE_DISABLED = \"disabled\" as const;\n\n/**\n * Enum value \"error\" for attribute {@link ATTR_FEATURE_FLAG_EVALUATION_REASON}.\n *\n * The resolved value was the result of an error.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_EVALUATION_REASON_VALUE_ERROR = \"error\" as const;\n\n/**\n * Enum value \"split\" for attribute {@link ATTR_FEATURE_FLAG_EVALUATION_REASON}.\n *\n * The resolved value was the result of pseudorandom assignment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_EVALUATION_REASON_VALUE_SPLIT = \"split\" as const;\n\n/**\n * Enum value \"stale\" for attribute {@link ATTR_FEATURE_FLAG_EVALUATION_REASON}.\n *\n * The resolved value is non-authoritative or possibly out of date\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_EVALUATION_REASON_VALUE_STALE = \"stale\" as const;\n\n/**\n * Enum value \"static\" for attribute {@link ATTR_FEATURE_FLAG_EVALUATION_REASON}.\n *\n * The resolved value is static (no dynamic evaluation).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_EVALUATION_REASON_VALUE_STATIC = \"static\" as const;\n\n/**\n * Enum value \"targeting_match\" for attribute {@link ATTR_FEATURE_FLAG_EVALUATION_REASON}.\n *\n * The resolved value was the result of a dynamic evaluation, such as a rule or specific user-targeting.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_EVALUATION_REASON_VALUE_TARGETING_MATCH = \"targeting_match\" as const;\n\n/**\n * Enum value \"unknown\" for attribute {@link ATTR_FEATURE_FLAG_EVALUATION_REASON}.\n *\n * The reason for the resolved value could not be determined.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_EVALUATION_REASON_VALUE_UNKNOWN = \"unknown\" as const;\n\n/**\n * The lookup key of the feature flag.\n *\n * @example logo-color\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FEATURE_FLAG_KEY = 'feature_flag.key' as const;\n\n/**\n * Identifies the feature flag provider.\n *\n * @example Flag Manager\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FEATURE_FLAG_PROVIDER_NAME = 'feature_flag.provider.name' as const;\n\n/**\n * The reason code which shows how a feature flag value was determined.\n *\n * @example static\n * @example targeting_match\n * @example error\n * @example default\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FEATURE_FLAG_RESULT_REASON = 'feature_flag.result.reason' as const;\n\n/**\n * Enum value \"cached\" for attribute {@link ATTR_FEATURE_FLAG_RESULT_REASON}.\n *\n * The resolved value was retrieved from cache.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_RESULT_REASON_VALUE_CACHED = \"cached\" as const;\n\n/**\n * Enum value \"default\" for attribute {@link ATTR_FEATURE_FLAG_RESULT_REASON}.\n *\n * The resolved value fell back to a pre-configured value (no dynamic evaluation occurred or dynamic evaluation yielded no result).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_RESULT_REASON_VALUE_DEFAULT = \"default\" as const;\n\n/**\n * Enum value \"disabled\" for attribute {@link ATTR_FEATURE_FLAG_RESULT_REASON}.\n *\n * The resolved value was the result of the flag being disabled in the management system.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_RESULT_REASON_VALUE_DISABLED = \"disabled\" as const;\n\n/**\n * Enum value \"error\" for attribute {@link ATTR_FEATURE_FLAG_RESULT_REASON}.\n *\n * The resolved value was the result of an error.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_RESULT_REASON_VALUE_ERROR = \"error\" as const;\n\n/**\n * Enum value \"split\" for attribute {@link ATTR_FEATURE_FLAG_RESULT_REASON}.\n *\n * The resolved value was the result of pseudorandom assignment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_RESULT_REASON_VALUE_SPLIT = \"split\" as const;\n\n/**\n * Enum value \"stale\" for attribute {@link ATTR_FEATURE_FLAG_RESULT_REASON}.\n *\n * The resolved value is non-authoritative or possibly out of date\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_RESULT_REASON_VALUE_STALE = \"stale\" as const;\n\n/**\n * Enum value \"static\" for attribute {@link ATTR_FEATURE_FLAG_RESULT_REASON}.\n *\n * The resolved value is static (no dynamic evaluation).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_RESULT_REASON_VALUE_STATIC = \"static\" as const;\n\n/**\n * Enum value \"targeting_match\" for attribute {@link ATTR_FEATURE_FLAG_RESULT_REASON}.\n *\n * The resolved value was the result of a dynamic evaluation, such as a rule or specific user-targeting.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_RESULT_REASON_VALUE_TARGETING_MATCH = \"targeting_match\" as const;\n\n/**\n * Enum value \"unknown\" for attribute {@link ATTR_FEATURE_FLAG_RESULT_REASON}.\n *\n * The reason for the resolved value could not be determined.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const FEATURE_FLAG_RESULT_REASON_VALUE_UNKNOWN = \"unknown\" as const;\n\n/**\n * The evaluated value of the feature flag.\n *\n * @example #ff0000\n * @example true\n * @example 3\n *\n * @note With some feature flag providers, feature flag results can be quite large or contain private or sensitive details.\n * Because of this, `feature_flag.result.variant` is often the preferred attribute if it is available.\n *\n * It may be desirable to redact or otherwise limit the size and scope of `feature_flag.result.value` if possible.\n * Because the evaluated flag value is unstructured and may be any type, it is left to the instrumentation author to determine how best to achieve this.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FEATURE_FLAG_RESULT_VALUE = 'feature_flag.result.value' as const;\n\n/**\n * A semantic identifier for an evaluated flag value.\n *\n * @example red\n * @example true\n * @example on\n *\n * @note A semantic identifier, commonly referred to as a variant, provides a means\n * for referring to a value without including the value itself. This can\n * provide additional context for understanding the meaning behind a value.\n * For example, the variant `red` maybe be used for the value `#c05543`.\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FEATURE_FLAG_RESULT_VARIANT = 'feature_flag.result.variant' as const;\n\n/**\n * The identifier of the [flag set](https://openfeature.dev/specification/glossary/#flag-set) to which the feature flag belongs.\n *\n * @example proj-1\n * @example ab98sgs\n * @example service1/dev\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FEATURE_FLAG_SET_ID = 'feature_flag.set.id' as const;\n\n/**\n * Deprecated, use `feature_flag.result.variant` instead.\n *\n * @example red\n * @example true\n * @example on\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `feature_flag.result.variant`.\n */\nexport const ATTR_FEATURE_FLAG_VARIANT = 'feature_flag.variant' as const;\n\n/**\n * The version of the ruleset used during the evaluation. This may be any stable value which uniquely identifies the ruleset.\n *\n * @example 1\n * @example 01ABCDEF\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FEATURE_FLAG_VERSION = 'feature_flag.version' as const;\n\n/**\n * Time when the file was last accessed, in ISO 8601 format.\n *\n * @example 2021-01-01T12:00:00Z\n *\n * @note This attribute might not be supported by some file systems — NFS, FAT32, in embedded OS, etc.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_ACCESSED = 'file.accessed' as const;\n\n/**\n * Array of file attributes.\n *\n * @example [\"readonly\", \"hidden\"]\n *\n * @note Attributes names depend on the OS or file system. Here’s a non-exhaustive list of values expected for this attribute: `archive`, `compressed`, `directory`, `encrypted`, `execute`, `hidden`, `immutable`, `journaled`, `read`, `readonly`, `symbolic link`, `system`, `temporary`, `write`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_ATTRIBUTES = 'file.attributes' as const;\n\n/**\n * Time when the file attributes or metadata was last changed, in ISO 8601 format.\n *\n * @example 2021-01-01T12:00:00Z\n *\n * @note `file.changed` captures the time when any of the file's properties or attributes (including the content) are changed, while `file.modified` captures the timestamp when the file content is modified.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_CHANGED = 'file.changed' as const;\n\n/**\n * Time when the file was created, in ISO 8601 format.\n *\n * @example 2021-01-01T12:00:00Z\n *\n * @note This attribute might not be supported by some file systems — NFS, FAT32, in embedded OS, etc.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_CREATED = 'file.created' as const;\n\n/**\n * Directory where the file is located. It should include the drive letter, when appropriate.\n *\n * @example /home/user\n * @example C:\\\\Program Files\\\\MyApp\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_DIRECTORY = 'file.directory' as const;\n\n/**\n * File extension, excluding the leading dot.\n *\n * @example png\n * @example gz\n *\n * @note When the file name has multiple extensions (example.tar.gz), only the last one should be captured (\"gz\", not \"tar.gz\").\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_EXTENSION = 'file.extension' as const;\n\n/**\n * Name of the fork. A fork is additional data associated with a filesystem object.\n *\n * @example Zone.Identifier\n *\n * @note On Linux, a resource fork is used to store additional data with a filesystem object. A file always has at least one fork for the data portion, and additional forks may exist.\n * On NTFS, this is analogous to an Alternate Data Stream (ADS), and the default data stream for a file is just called $DATA. Zone.Identifier is commonly used by Windows to track contents downloaded from the Internet. An ADS is typically of the form: C:\\\\path\\\\to\\\\filename.extension:some_fork_name, and some_fork_name is the value that should populate `fork_name`. `filename.extension` should populate `file.name`, and `extension` should populate `file.extension`. The full path, `file.path`, will include the fork name.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_FORK_NAME = 'file.fork_name' as const;\n\n/**\n * Primary Group ID (GID) of the file.\n *\n * @example 1000\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_GROUP_ID = 'file.group.id' as const;\n\n/**\n * Primary group name of the file.\n *\n * @example users\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_GROUP_NAME = 'file.group.name' as const;\n\n/**\n * Inode representing the file in the filesystem.\n *\n * @example 256383\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_INODE = 'file.inode' as const;\n\n/**\n * Mode of the file in octal representation.\n *\n * @example 0640\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_MODE = 'file.mode' as const;\n\n/**\n * Time when the file content was last modified, in ISO 8601 format.\n *\n * @example 2021-01-01T12:00:00Z\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_MODIFIED = 'file.modified' as const;\n\n/**\n * Name of the file including the extension, without the directory.\n *\n * @example example.png\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_NAME = 'file.name' as const;\n\n/**\n * The user ID (UID) or security identifier (SID) of the file owner.\n *\n * @example 1000\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_OWNER_ID = 'file.owner.id' as const;\n\n/**\n * Username of the file owner.\n *\n * @example root\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_OWNER_NAME = 'file.owner.name' as const;\n\n/**\n * Full path to the file, including the file name. It should include the drive letter, when appropriate.\n *\n * @example /home/alice/example.png\n * @example C:\\\\Program Files\\\\MyApp\\\\myapp.exe\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_PATH = 'file.path' as const;\n\n/**\n * File size in bytes.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_SIZE = 'file.size' as const;\n\n/**\n * Path to the target of a symbolic link.\n *\n * @example /usr/bin/python3\n *\n * @note This attribute is only applicable to symbolic links.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_FILE_SYMBOLIC_LINK_TARGET_PATH = 'file.symbolic_link.target_path' as const;\n\n/**\n * The container within GCP where the AppHub application is defined.\n *\n * @example projects/my-container-project\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_APPLICATION_CONTAINER = 'gcp.apphub.application.container' as const;\n\n/**\n * The name of the application as configured in AppHub.\n *\n * @example my-application\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_APPLICATION_ID = 'gcp.apphub.application.id' as const;\n\n/**\n * The GCP zone or region where the application is defined.\n *\n * @example us-central1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_APPLICATION_LOCATION = 'gcp.apphub.application.location' as const;\n\n/**\n * Criticality of a service indicates its importance to the business.\n *\n * @note [See AppHub type enum](https://cloud.google.com/app-hub/docs/reference/rest/v1/Attributes#type)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_SERVICE_CRITICALITY_TYPE = 'gcp.apphub.service.criticality_type' as const;\n\n/**\n * Enum value \"HIGH\" for attribute {@link ATTR_GCP_APPHUB_SERVICE_CRITICALITY_TYPE}.\n *\n * High impact.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_SERVICE_CRITICALITY_TYPE_VALUE_HIGH = \"HIGH\" as const;\n\n/**\n * Enum value \"LOW\" for attribute {@link ATTR_GCP_APPHUB_SERVICE_CRITICALITY_TYPE}.\n *\n * Low impact.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_SERVICE_CRITICALITY_TYPE_VALUE_LOW = \"LOW\" as const;\n\n/**\n * Enum value \"MEDIUM\" for attribute {@link ATTR_GCP_APPHUB_SERVICE_CRITICALITY_TYPE}.\n *\n * Medium impact.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_SERVICE_CRITICALITY_TYPE_VALUE_MEDIUM = \"MEDIUM\" as const;\n\n/**\n * Enum value \"MISSION_CRITICAL\" for attribute {@link ATTR_GCP_APPHUB_SERVICE_CRITICALITY_TYPE}.\n *\n * Mission critical service.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_SERVICE_CRITICALITY_TYPE_VALUE_MISSION_CRITICAL = \"MISSION_CRITICAL\" as const;\n\n/**\n * Environment of a service is the stage of a software lifecycle.\n *\n * @note [See AppHub environment type](https://cloud.google.com/app-hub/docs/reference/rest/v1/Attributes#type_1)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_SERVICE_ENVIRONMENT_TYPE = 'gcp.apphub.service.environment_type' as const;\n\n/**\n * Enum value \"DEVELOPMENT\" for attribute {@link ATTR_GCP_APPHUB_SERVICE_ENVIRONMENT_TYPE}.\n *\n * Development environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_SERVICE_ENVIRONMENT_TYPE_VALUE_DEVELOPMENT = \"DEVELOPMENT\" as const;\n\n/**\n * Enum value \"PRODUCTION\" for attribute {@link ATTR_GCP_APPHUB_SERVICE_ENVIRONMENT_TYPE}.\n *\n * Production environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_SERVICE_ENVIRONMENT_TYPE_VALUE_PRODUCTION = \"PRODUCTION\" as const;\n\n/**\n * Enum value \"STAGING\" for attribute {@link ATTR_GCP_APPHUB_SERVICE_ENVIRONMENT_TYPE}.\n *\n * Staging environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_SERVICE_ENVIRONMENT_TYPE_VALUE_STAGING = \"STAGING\" as const;\n\n/**\n * Enum value \"TEST\" for attribute {@link ATTR_GCP_APPHUB_SERVICE_ENVIRONMENT_TYPE}.\n *\n * Test environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_SERVICE_ENVIRONMENT_TYPE_VALUE_TEST = \"TEST\" as const;\n\n/**\n * The name of the service as configured in AppHub.\n *\n * @example my-service\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_SERVICE_ID = 'gcp.apphub.service.id' as const;\n\n/**\n * Criticality of a workload indicates its importance to the business.\n *\n * @note [See AppHub type enum](https://cloud.google.com/app-hub/docs/reference/rest/v1/Attributes#type)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_WORKLOAD_CRITICALITY_TYPE = 'gcp.apphub.workload.criticality_type' as const;\n\n/**\n * Enum value \"HIGH\" for attribute {@link ATTR_GCP_APPHUB_WORKLOAD_CRITICALITY_TYPE}.\n *\n * High impact.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_WORKLOAD_CRITICALITY_TYPE_VALUE_HIGH = \"HIGH\" as const;\n\n/**\n * Enum value \"LOW\" for attribute {@link ATTR_GCP_APPHUB_WORKLOAD_CRITICALITY_TYPE}.\n *\n * Low impact.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_WORKLOAD_CRITICALITY_TYPE_VALUE_LOW = \"LOW\" as const;\n\n/**\n * Enum value \"MEDIUM\" for attribute {@link ATTR_GCP_APPHUB_WORKLOAD_CRITICALITY_TYPE}.\n *\n * Medium impact.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_WORKLOAD_CRITICALITY_TYPE_VALUE_MEDIUM = \"MEDIUM\" as const;\n\n/**\n * Enum value \"MISSION_CRITICAL\" for attribute {@link ATTR_GCP_APPHUB_WORKLOAD_CRITICALITY_TYPE}.\n *\n * Mission critical service.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_WORKLOAD_CRITICALITY_TYPE_VALUE_MISSION_CRITICAL = \"MISSION_CRITICAL\" as const;\n\n/**\n * Environment of a workload is the stage of a software lifecycle.\n *\n * @note [See AppHub environment type](https://cloud.google.com/app-hub/docs/reference/rest/v1/Attributes#type_1)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_WORKLOAD_ENVIRONMENT_TYPE = 'gcp.apphub.workload.environment_type' as const;\n\n/**\n * Enum value \"DEVELOPMENT\" for attribute {@link ATTR_GCP_APPHUB_WORKLOAD_ENVIRONMENT_TYPE}.\n *\n * Development environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_WORKLOAD_ENVIRONMENT_TYPE_VALUE_DEVELOPMENT = \"DEVELOPMENT\" as const;\n\n/**\n * Enum value \"PRODUCTION\" for attribute {@link ATTR_GCP_APPHUB_WORKLOAD_ENVIRONMENT_TYPE}.\n *\n * Production environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_WORKLOAD_ENVIRONMENT_TYPE_VALUE_PRODUCTION = \"PRODUCTION\" as const;\n\n/**\n * Enum value \"STAGING\" for attribute {@link ATTR_GCP_APPHUB_WORKLOAD_ENVIRONMENT_TYPE}.\n *\n * Staging environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_WORKLOAD_ENVIRONMENT_TYPE_VALUE_STAGING = \"STAGING\" as const;\n\n/**\n * Enum value \"TEST\" for attribute {@link ATTR_GCP_APPHUB_WORKLOAD_ENVIRONMENT_TYPE}.\n *\n * Test environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_WORKLOAD_ENVIRONMENT_TYPE_VALUE_TEST = \"TEST\" as const;\n\n/**\n * The name of the workload as configured in AppHub.\n *\n * @example my-workload\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_WORKLOAD_ID = 'gcp.apphub.workload.id' as const;\n\n/**\n * The container within GCP where the AppHub destination application is defined.\n *\n * @example projects/my-container-project\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_DESTINATION_APPLICATION_CONTAINER = 'gcp.apphub_destination.application.container' as const;\n\n/**\n * The name of the destination application as configured in AppHub.\n *\n * @example my-application\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_DESTINATION_APPLICATION_ID = 'gcp.apphub_destination.application.id' as const;\n\n/**\n * The GCP zone or region where the destination application is defined.\n *\n * @example us-central1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_DESTINATION_APPLICATION_LOCATION = 'gcp.apphub_destination.application.location' as const;\n\n/**\n * Criticality of a destination workload indicates its importance to the business as specified in [AppHub type enum](https://cloud.google.com/app-hub/docs/reference/rest/v1/Attributes#type)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_DESTINATION_SERVICE_CRITICALITY_TYPE = 'gcp.apphub_destination.service.criticality_type' as const;\n\n/**\n * Enum value \"HIGH\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_SERVICE_CRITICALITY_TYPE}.\n *\n * High impact.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_SERVICE_CRITICALITY_TYPE_VALUE_HIGH = \"HIGH\" as const;\n\n/**\n * Enum value \"LOW\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_SERVICE_CRITICALITY_TYPE}.\n *\n * Low impact.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_SERVICE_CRITICALITY_TYPE_VALUE_LOW = \"LOW\" as const;\n\n/**\n * Enum value \"MEDIUM\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_SERVICE_CRITICALITY_TYPE}.\n *\n * Medium impact.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_SERVICE_CRITICALITY_TYPE_VALUE_MEDIUM = \"MEDIUM\" as const;\n\n/**\n * Enum value \"MISSION_CRITICAL\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_SERVICE_CRITICALITY_TYPE}.\n *\n * Mission critical service.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_SERVICE_CRITICALITY_TYPE_VALUE_MISSION_CRITICAL = \"MISSION_CRITICAL\" as const;\n\n/**\n * Software lifecycle stage of a destination service as defined [AppHub environment type](https://cloud.google.com/app-hub/docs/reference/rest/v1/Attributes#type_1)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_DESTINATION_SERVICE_ENVIRONMENT_TYPE = 'gcp.apphub_destination.service.environment_type' as const;\n\n/**\n * Enum value \"DEVELOPMENT\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_SERVICE_ENVIRONMENT_TYPE}.\n *\n * Development environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_SERVICE_ENVIRONMENT_TYPE_VALUE_DEVELOPMENT = \"DEVELOPMENT\" as const;\n\n/**\n * Enum value \"PRODUCTION\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_SERVICE_ENVIRONMENT_TYPE}.\n *\n * Production environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_SERVICE_ENVIRONMENT_TYPE_VALUE_PRODUCTION = \"PRODUCTION\" as const;\n\n/**\n * Enum value \"STAGING\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_SERVICE_ENVIRONMENT_TYPE}.\n *\n * Staging environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_SERVICE_ENVIRONMENT_TYPE_VALUE_STAGING = \"STAGING\" as const;\n\n/**\n * Enum value \"TEST\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_SERVICE_ENVIRONMENT_TYPE}.\n *\n * Test environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_SERVICE_ENVIRONMENT_TYPE_VALUE_TEST = \"TEST\" as const;\n\n/**\n * The name of the destination service as configured in AppHub.\n *\n * @example my-service\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_DESTINATION_SERVICE_ID = 'gcp.apphub_destination.service.id' as const;\n\n/**\n * Criticality of a destination workload indicates its importance to the business as specified in [AppHub type enum](https://cloud.google.com/app-hub/docs/reference/rest/v1/Attributes#type)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_DESTINATION_WORKLOAD_CRITICALITY_TYPE = 'gcp.apphub_destination.workload.criticality_type' as const;\n\n/**\n * Enum value \"HIGH\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_WORKLOAD_CRITICALITY_TYPE}.\n *\n * High impact.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_WORKLOAD_CRITICALITY_TYPE_VALUE_HIGH = \"HIGH\" as const;\n\n/**\n * Enum value \"LOW\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_WORKLOAD_CRITICALITY_TYPE}.\n *\n * Low impact.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_WORKLOAD_CRITICALITY_TYPE_VALUE_LOW = \"LOW\" as const;\n\n/**\n * Enum value \"MEDIUM\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_WORKLOAD_CRITICALITY_TYPE}.\n *\n * Medium impact.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_WORKLOAD_CRITICALITY_TYPE_VALUE_MEDIUM = \"MEDIUM\" as const;\n\n/**\n * Enum value \"MISSION_CRITICAL\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_WORKLOAD_CRITICALITY_TYPE}.\n *\n * Mission critical service.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_WORKLOAD_CRITICALITY_TYPE_VALUE_MISSION_CRITICAL = \"MISSION_CRITICAL\" as const;\n\n/**\n * Environment of a destination workload is the stage of a software lifecycle as provided in the [AppHub environment type](https://cloud.google.com/app-hub/docs/reference/rest/v1/Attributes#type_1)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_DESTINATION_WORKLOAD_ENVIRONMENT_TYPE = 'gcp.apphub_destination.workload.environment_type' as const;\n\n/**\n * Enum value \"DEVELOPMENT\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_WORKLOAD_ENVIRONMENT_TYPE}.\n *\n * Development environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_WORKLOAD_ENVIRONMENT_TYPE_VALUE_DEVELOPMENT = \"DEVELOPMENT\" as const;\n\n/**\n * Enum value \"PRODUCTION\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_WORKLOAD_ENVIRONMENT_TYPE}.\n *\n * Production environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_WORKLOAD_ENVIRONMENT_TYPE_VALUE_PRODUCTION = \"PRODUCTION\" as const;\n\n/**\n * Enum value \"STAGING\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_WORKLOAD_ENVIRONMENT_TYPE}.\n *\n * Staging environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_WORKLOAD_ENVIRONMENT_TYPE_VALUE_STAGING = \"STAGING\" as const;\n\n/**\n * Enum value \"TEST\" for attribute {@link ATTR_GCP_APPHUB_DESTINATION_WORKLOAD_ENVIRONMENT_TYPE}.\n *\n * Test environment.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GCP_APPHUB_DESTINATION_WORKLOAD_ENVIRONMENT_TYPE_VALUE_TEST = \"TEST\" as const;\n\n/**\n * The name of the destination workload as configured in AppHub.\n *\n * @example my-workload\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_APPHUB_DESTINATION_WORKLOAD_ID = 'gcp.apphub_destination.workload.id' as const;\n\n/**\n * Identifies the Google Cloud service for which the official client library is intended.\n *\n * @example appengine\n * @example run\n * @example firestore\n * @example alloydb\n * @example spanner\n *\n * @note Intended to be a stable identifier for Google Cloud client libraries that is uniform across implementation languages. The value should be derived from the canonical service domain for the service; for example, 'foo.googleapis.com' should result in a value of 'foo'.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_CLIENT_SERVICE = 'gcp.client.service' as const;\n\n/**\n * The name of the Cloud Run [execution](https://cloud.google.com/run/docs/managing/job-executions) being run for the Job, as set by the [`CLOUD_RUN_EXECUTION`](https://cloud.google.com/run/docs/container-contract#jobs-env-vars) environment variable.\n *\n * @example job-name-xxxx\n * @example sample-job-mdw84\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_CLOUD_RUN_JOB_EXECUTION = 'gcp.cloud_run.job.execution' as const;\n\n/**\n * The index for a task within an execution as provided by the [`CLOUD_RUN_TASK_INDEX`](https://cloud.google.com/run/docs/container-contract#jobs-env-vars) environment variable.\n *\n * @example 0\n * @example 1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_CLOUD_RUN_JOB_TASK_INDEX = 'gcp.cloud_run.job.task_index' as const;\n\n/**\n * The hostname of a GCE instance. This is the full value of the default or [custom hostname](https://cloud.google.com/compute/docs/instances/custom-hostname-vm).\n *\n * @example my-host1234.example.com\n * @example sample-vm.us-west1-b.c.my-project.internal\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_GCE_INSTANCE_HOSTNAME = 'gcp.gce.instance.hostname' as const;\n\n/**\n * The instance name of a GCE instance. This is the value provided by `host.name`, the visible name of the instance in the Cloud Console UI, and the prefix for the default hostname of the instance as defined by the [default internal DNS name](https://cloud.google.com/compute/docs/internal-dns#instance-fully-qualified-domain-names).\n *\n * @example instance-1\n * @example my-vm-name\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GCP_GCE_INSTANCE_NAME = 'gcp.gce.instance.name' as const;\n\n/**\n * Free-form description of the GenAI agent provided by the application.\n *\n * @example Helps with math problems\n * @example Generates fiction stories\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_AGENT_DESCRIPTION = 'gen_ai.agent.description' as const;\n\n/**\n * The unique identifier of the GenAI agent.\n *\n * @example asst_5j66UpCpwteGg4YSxUnt7lPY\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_AGENT_ID = 'gen_ai.agent.id' as const;\n\n/**\n * Human-readable name of the GenAI agent provided by the application.\n *\n * @example Math Tutor\n * @example Fiction Writer\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_AGENT_NAME = 'gen_ai.agent.name' as const;\n\n/**\n * Deprecated, use Event API to report completions contents.\n *\n * @example [{'role': 'assistant', 'content': 'The capital of France is Paris.'}]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Removed, no replacement at this time.\n */\nexport const ATTR_GEN_AI_COMPLETION = 'gen_ai.completion' as const;\n\n/**\n * The unique identifier for a conversation (session, thread), used to store and correlate messages within this conversation.\n *\n * @example conv_5j66UpCpwteGg4YSxUnt7lPY\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_CONVERSATION_ID = 'gen_ai.conversation.id' as const;\n\n/**\n * The data source identifier.\n *\n * @example H7STPQYOND\n *\n * @note Data sources are used by AI agents and RAG applications to store grounding data. A data source may be an external database, object store, document collection, website, or any other storage system used by the GenAI agent or application. The `gen_ai.data_source.id` **SHOULD** match the identifier used by the GenAI system rather than a name specific to the external storage, such as a database or object store. Semantic conventions referencing `gen_ai.data_source.id` **MAY** also leverage additional attributes, such as `db.*`, to further identify and describe the data source.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_DATA_SOURCE_ID = 'gen_ai.data_source.id' as const;\n\n/**\n * The number of dimensions the resulting output embeddings should have.\n *\n * @example 512\n * @example 1024\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_EMBEDDINGS_DIMENSION_COUNT = 'gen_ai.embeddings.dimension.count' as const;\n\n/**\n * A free-form explanation for the assigned score provided by the evaluator.\n *\n * @example The response is factually accurate but lacks sufficient detail to fully address the question.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_EVALUATION_EXPLANATION = 'gen_ai.evaluation.explanation' as const;\n\n/**\n * The name of the evaluation metric used for the GenAI response.\n *\n * @example Relevance\n * @example IntentResolution\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_EVALUATION_NAME = 'gen_ai.evaluation.name' as const;\n\n/**\n * Human readable label for evaluation.\n *\n * @example relevant\n * @example not_relevant\n * @example correct\n * @example incorrect\n * @example pass\n * @example fail\n *\n * @note This attribute provides a human-readable interpretation of the evaluation score produced by an evaluator. For example, a score value of 1 could mean \"relevant\" in one evaluation system and \"not relevant\" in another, depending on the scoring range and evaluator. The label **SHOULD** have low cardinality. Possible values depend on the evaluation metric and evaluator used; implementations **SHOULD** document the possible values.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_EVALUATION_SCORE_LABEL = 'gen_ai.evaluation.score.label' as const;\n\n/**\n * The evaluation score returned by the evaluator.\n *\n * @example 4.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_EVALUATION_SCORE_VALUE = 'gen_ai.evaluation.score.value' as const;\n\n/**\n * The chat history provided to the model as an input.\n *\n * @example [\n * {\n * \"role\": \"user\",\n * \"parts\": [\n * {\n * \"type\": \"text\",\n * \"content\": \"Weather in Paris?\"\n * }\n * ]\n * },\n * {\n * \"role\": \"assistant\",\n * \"parts\": [\n * {\n * \"type\": \"tool_call\",\n * \"id\": \"call_VSPygqKTWdrhaFErNvMV18Yl\",\n * \"name\": \"get_weather\",\n * \"arguments\": {\n * \"location\": \"Paris\"\n * }\n * }\n * ]\n * },\n * {\n * \"role\": \"tool\",\n * \"parts\": [\n * {\n * \"type\": \"tool_call_response\",\n * \"id\": \" call_VSPygqKTWdrhaFErNvMV18Yl\",\n * \"result\": \"rainy, 57°F\"\n * }\n * ]\n * }\n * ]\n *\n * @note Instrumentations **MUST** follow [Input messages JSON schema](/docs/gen-ai/gen-ai-input-messages.json).\n * When the attribute is recorded on events, it **MUST** be recorded in structured\n * form. When recorded on spans, it **MAY** be recorded as a JSON string if structured\n * format is not supported and **SHOULD** be recorded in structured form otherwise.\n *\n * Messages **MUST** be provided in the order they were sent to the model.\n * Instrumentations **MAY** provide a way for users to filter or truncate\n * input messages.\n *\n * > [!Warning]\n * > This attribute is likely to contain sensitive information including user/PII data.\n *\n * See [Recording content on attributes](/docs/gen-ai/gen-ai-spans.md#recording-content-on-attributes)\n * section for more details.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_INPUT_MESSAGES = 'gen_ai.input.messages' as const;\n\n/**\n * Deprecated, use `gen_ai.output.type`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `gen_ai.output.type`.\n */\nexport const ATTR_GEN_AI_OPENAI_REQUEST_RESPONSE_FORMAT = 'gen_ai.openai.request.response_format' as const;\n\n/**\n * Enum value \"json_object\" for attribute {@link ATTR_GEN_AI_OPENAI_REQUEST_RESPONSE_FORMAT}.\n *\n * JSON object response format\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OPENAI_REQUEST_RESPONSE_FORMAT_VALUE_JSON_OBJECT = \"json_object\" as const;\n\n/**\n * Enum value \"json_schema\" for attribute {@link ATTR_GEN_AI_OPENAI_REQUEST_RESPONSE_FORMAT}.\n *\n * JSON schema response format\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OPENAI_REQUEST_RESPONSE_FORMAT_VALUE_JSON_SCHEMA = \"json_schema\" as const;\n\n/**\n * Enum value \"text\" for attribute {@link ATTR_GEN_AI_OPENAI_REQUEST_RESPONSE_FORMAT}.\n *\n * Text response format\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OPENAI_REQUEST_RESPONSE_FORMAT_VALUE_TEXT = \"text\" as const;\n\n/**\n * Deprecated, use `gen_ai.request.seed`.\n *\n * @example 100\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `gen_ai.request.seed`.\n */\nexport const ATTR_GEN_AI_OPENAI_REQUEST_SEED = 'gen_ai.openai.request.seed' as const;\n\n/**\n * Deprecated, use `openai.request.service_tier`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `openai.request.service_tier`.\n */\nexport const ATTR_GEN_AI_OPENAI_REQUEST_SERVICE_TIER = 'gen_ai.openai.request.service_tier' as const;\n\n/**\n * Enum value \"auto\" for attribute {@link ATTR_GEN_AI_OPENAI_REQUEST_SERVICE_TIER}.\n *\n * The system will utilize scale tier credits until they are exhausted.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OPENAI_REQUEST_SERVICE_TIER_VALUE_AUTO = \"auto\" as const;\n\n/**\n * Enum value \"default\" for attribute {@link ATTR_GEN_AI_OPENAI_REQUEST_SERVICE_TIER}.\n *\n * The system will utilize the default scale tier.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OPENAI_REQUEST_SERVICE_TIER_VALUE_DEFAULT = \"default\" as const;\n\n/**\n * Deprecated, use `openai.response.service_tier`.\n *\n * @example scale\n * @example default\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `openai.response.service_tier`.\n */\nexport const ATTR_GEN_AI_OPENAI_RESPONSE_SERVICE_TIER = 'gen_ai.openai.response.service_tier' as const;\n\n/**\n * Deprecated, use `openai.response.system_fingerprint`.\n *\n * @example fp_44709d6fcb\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `openai.response.system_fingerprint`.\n */\nexport const ATTR_GEN_AI_OPENAI_RESPONSE_SYSTEM_FINGERPRINT = 'gen_ai.openai.response.system_fingerprint' as const;\n\n/**\n * The name of the operation being performed.\n *\n * @note If one of the predefined values applies, but specific system uses a different name it's **RECOMMENDED** to document it in the semantic conventions for specific GenAI system and use system-specific name in the instrumentation. If a different name is not documented, instrumentation libraries **SHOULD** use applicable predefined value.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_OPERATION_NAME = 'gen_ai.operation.name' as const;\n\n/**\n * Enum value \"chat\" for attribute {@link ATTR_GEN_AI_OPERATION_NAME}.\n *\n * Chat completion operation such as [OpenAI Chat API](https://platform.openai.com/docs/api-reference/chat)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OPERATION_NAME_VALUE_CHAT = \"chat\" as const;\n\n/**\n * Enum value \"create_agent\" for attribute {@link ATTR_GEN_AI_OPERATION_NAME}.\n *\n * Create GenAI agent\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OPERATION_NAME_VALUE_CREATE_AGENT = \"create_agent\" as const;\n\n/**\n * Enum value \"embeddings\" for attribute {@link ATTR_GEN_AI_OPERATION_NAME}.\n *\n * Embeddings operation such as [OpenAI Create embeddings API](https://platform.openai.com/docs/api-reference/embeddings/create)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OPERATION_NAME_VALUE_EMBEDDINGS = \"embeddings\" as const;\n\n/**\n * Enum value \"execute_tool\" for attribute {@link ATTR_GEN_AI_OPERATION_NAME}.\n *\n * Execute a tool\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OPERATION_NAME_VALUE_EXECUTE_TOOL = \"execute_tool\" as const;\n\n/**\n * Enum value \"generate_content\" for attribute {@link ATTR_GEN_AI_OPERATION_NAME}.\n *\n * Multimodal content generation operation such as [Gemini Generate Content](https://ai.google.dev/api/generate-content)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OPERATION_NAME_VALUE_GENERATE_CONTENT = \"generate_content\" as const;\n\n/**\n * Enum value \"invoke_agent\" for attribute {@link ATTR_GEN_AI_OPERATION_NAME}.\n *\n * Invoke GenAI agent\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OPERATION_NAME_VALUE_INVOKE_AGENT = \"invoke_agent\" as const;\n\n/**\n * Enum value \"text_completion\" for attribute {@link ATTR_GEN_AI_OPERATION_NAME}.\n *\n * Text completions operation such as [OpenAI Completions API (Legacy)](https://platform.openai.com/docs/api-reference/completions)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OPERATION_NAME_VALUE_TEXT_COMPLETION = \"text_completion\" as const;\n\n/**\n * Messages returned by the model where each message represents a specific model response (choice, candidate).\n *\n * @example [\n * {\n * \"role\": \"assistant\",\n * \"parts\": [\n * {\n * \"type\": \"text\",\n * \"content\": \"The weather in Paris is currently rainy with a temperature of 57°F.\"\n * }\n * ],\n * \"finish_reason\": \"stop\"\n * }\n * ]\n *\n * @note Instrumentations **MUST** follow [Output messages JSON schema](/docs/gen-ai/gen-ai-output-messages.json)\n *\n * Each message represents a single output choice/candidate generated by\n * the model. Each message corresponds to exactly one generation\n * (choice/candidate) and vice versa - one choice cannot be split across\n * multiple messages or one message cannot contain parts from multiple choices.\n *\n * When the attribute is recorded on events, it **MUST** be recorded in structured\n * form. When recorded on spans, it **MAY** be recorded as a JSON string if structured\n * format is not supported and **SHOULD** be recorded in structured form otherwise.\n *\n * Instrumentations **MAY** provide a way for users to filter or truncate\n * output messages.\n *\n * > [!Warning]\n * > This attribute is likely to contain sensitive information including user/PII data.\n *\n * See [Recording content on attributes](/docs/gen-ai/gen-ai-spans.md#recording-content-on-attributes)\n * section for more details.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_OUTPUT_MESSAGES = 'gen_ai.output.messages' as const;\n\n/**\n * Represents the content type requested by the client.\n *\n * @note This attribute **SHOULD** be used when the client requests output of a specific type. The model may return zero or more outputs of this type.\n * This attribute specifies the output modality and not the actual output format. For example, if an image is requested, the actual output could be a URL pointing to an image file.\n * Additional output format details may be recorded in the future in the `gen_ai.output.{type}.*` attributes.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_OUTPUT_TYPE = 'gen_ai.output.type' as const;\n\n/**\n * Enum value \"image\" for attribute {@link ATTR_GEN_AI_OUTPUT_TYPE}.\n *\n * Image\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OUTPUT_TYPE_VALUE_IMAGE = \"image\" as const;\n\n/**\n * Enum value \"json\" for attribute {@link ATTR_GEN_AI_OUTPUT_TYPE}.\n *\n * JSON object with known or unknown schema\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OUTPUT_TYPE_VALUE_JSON = \"json\" as const;\n\n/**\n * Enum value \"speech\" for attribute {@link ATTR_GEN_AI_OUTPUT_TYPE}.\n *\n * Speech\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OUTPUT_TYPE_VALUE_SPEECH = \"speech\" as const;\n\n/**\n * Enum value \"text\" for attribute {@link ATTR_GEN_AI_OUTPUT_TYPE}.\n *\n * Plain text\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_OUTPUT_TYPE_VALUE_TEXT = \"text\" as const;\n\n/**\n * Deprecated, use Event API to report prompt contents.\n *\n * @example [{'role': 'user', 'content': 'What is the capital of France?'}]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Removed, no replacement at this time.\n */\nexport const ATTR_GEN_AI_PROMPT = 'gen_ai.prompt' as const;\n\n/**\n * The name of the prompt that uniquely identifies it.\n *\n * @example analyze-code\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_PROMPT_NAME = 'gen_ai.prompt.name' as const;\n\n/**\n * The Generative AI provider as identified by the client or server instrumentation.\n *\n * @note The attribute **SHOULD** be set based on the instrumentation's best\n * knowledge and may differ from the actual model provider.\n *\n * Multiple providers, including Azure OpenAI, Gemini, and AI hosting platforms\n * are accessible using the OpenAI REST API and corresponding client libraries,\n * but may proxy or host models from different providers.\n *\n * The `gen_ai.request.model`, `gen_ai.response.model`, and `server.address`\n * attributes may help identify the actual system in use.\n *\n * The `gen_ai.provider.name` attribute acts as a discriminator that\n * identifies the GenAI telemetry format flavor specific to that provider\n * within GenAI semantic conventions.\n * It **SHOULD** be set consistently with provider-specific attributes and signals.\n * For example, GenAI spans, metrics, and events related to AWS Bedrock\n * should have the `gen_ai.provider.name` set to `aws.bedrock` and include\n * applicable `aws.bedrock.*` attributes and are not expected to include\n * `openai.*` attributes.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_PROVIDER_NAME = 'gen_ai.provider.name' as const;\n\n/**\n * Enum value \"anthropic\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [Anthropic](https://www.anthropic.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_ANTHROPIC = \"anthropic\" as const;\n\n/**\n * Enum value \"aws.bedrock\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [AWS Bedrock](https://aws.amazon.com/bedrock)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_AWS_BEDROCK = \"aws.bedrock\" as const;\n\n/**\n * Enum value \"azure.ai.inference\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * Azure AI Inference\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_AZURE_AI_INFERENCE = \"azure.ai.inference\" as const;\n\n/**\n * Enum value \"azure.ai.openai\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [Azure OpenAI](https://azure.microsoft.com/products/ai-services/openai-service/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_AZURE_AI_OPENAI = \"azure.ai.openai\" as const;\n\n/**\n * Enum value \"cohere\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [Cohere](https://cohere.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_COHERE = \"cohere\" as const;\n\n/**\n * Enum value \"deepseek\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [DeepSeek](https://www.deepseek.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_DEEPSEEK = \"deepseek\" as const;\n\n/**\n * Enum value \"gcp.gemini\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [Gemini](https://cloud.google.com/products/gemini)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_GCP_GEMINI = \"gcp.gemini\" as const;\n\n/**\n * Enum value \"gcp.gen_ai\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * Any Google generative AI endpoint\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_GCP_GEN_AI = \"gcp.gen_ai\" as const;\n\n/**\n * Enum value \"gcp.vertex_ai\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [Vertex AI](https://cloud.google.com/vertex-ai)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_GCP_VERTEX_AI = \"gcp.vertex_ai\" as const;\n\n/**\n * Enum value \"groq\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [Groq](https://groq.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_GROQ = \"groq\" as const;\n\n/**\n * Enum value \"ibm.watsonx.ai\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [IBM Watsonx AI](https://www.ibm.com/products/watsonx-ai)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_IBM_WATSONX_AI = \"ibm.watsonx.ai\" as const;\n\n/**\n * Enum value \"mistral_ai\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [Mistral AI](https://mistral.ai/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_MISTRAL_AI = \"mistral_ai\" as const;\n\n/**\n * Enum value \"openai\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [OpenAI](https://openai.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_OPENAI = \"openai\" as const;\n\n/**\n * Enum value \"perplexity\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [Perplexity](https://www.perplexity.ai/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_PERPLEXITY = \"perplexity\" as const;\n\n/**\n * Enum value \"x_ai\" for attribute {@link ATTR_GEN_AI_PROVIDER_NAME}.\n *\n * [xAI](https://x.ai/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_PROVIDER_NAME_VALUE_X_AI = \"x_ai\" as const;\n\n/**\n * The target number of candidate completions to return.\n *\n * @example 3\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_REQUEST_CHOICE_COUNT = 'gen_ai.request.choice.count' as const;\n\n/**\n * The encoding formats requested in an embeddings operation, if specified.\n *\n * @example [\"base64\"]\n * @example [\"float\", \"binary\"]\n *\n * @note In some GenAI systems the encoding formats are called embedding types. Also, some GenAI systems only accept a single format per request.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_REQUEST_ENCODING_FORMATS = 'gen_ai.request.encoding_formats' as const;\n\n/**\n * The frequency penalty setting for the GenAI request.\n *\n * @example 0.1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_REQUEST_FREQUENCY_PENALTY = 'gen_ai.request.frequency_penalty' as const;\n\n/**\n * The maximum number of tokens the model generates for a request.\n *\n * @example 100\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_REQUEST_MAX_TOKENS = 'gen_ai.request.max_tokens' as const;\n\n/**\n * The name of the GenAI model a request is being made to.\n *\n * @example \"gpt-4\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_REQUEST_MODEL = 'gen_ai.request.model' as const;\n\n/**\n * The presence penalty setting for the GenAI request.\n *\n * @example 0.1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_REQUEST_PRESENCE_PENALTY = 'gen_ai.request.presence_penalty' as const;\n\n/**\n * Requests with same seed value more likely to return same result.\n *\n * @example 100\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_REQUEST_SEED = 'gen_ai.request.seed' as const;\n\n/**\n * List of sequences that the model will use to stop generating further tokens.\n *\n * @example [\"forest\", \"lived\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_REQUEST_STOP_SEQUENCES = 'gen_ai.request.stop_sequences' as const;\n\n/**\n * The temperature setting for the GenAI request.\n *\n * @example 0.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_REQUEST_TEMPERATURE = 'gen_ai.request.temperature' as const;\n\n/**\n * The top_k sampling setting for the GenAI request.\n *\n * @example 1.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_REQUEST_TOP_K = 'gen_ai.request.top_k' as const;\n\n/**\n * The top_p sampling setting for the GenAI request.\n *\n * @example 1.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_REQUEST_TOP_P = 'gen_ai.request.top_p' as const;\n\n/**\n * Array of reasons the model stopped generating tokens, corresponding to each generation received.\n *\n * @example [\"stop\"]\n * @example [\"stop\", \"length\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_RESPONSE_FINISH_REASONS = 'gen_ai.response.finish_reasons' as const;\n\n/**\n * The unique identifier for the completion.\n *\n * @example chatcmpl-123\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_RESPONSE_ID = 'gen_ai.response.id' as const;\n\n/**\n * The name of the model that generated the response.\n *\n * @example gpt-4-0613\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_RESPONSE_MODEL = 'gen_ai.response.model' as const;\n\n/**\n * Deprecated, use `gen_ai.provider.name` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `gen_ai.provider.name`.\n */\nexport const ATTR_GEN_AI_SYSTEM = 'gen_ai.system' as const;\n\n/**\n * Enum value \"anthropic\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Anthropic\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_ANTHROPIC = \"anthropic\" as const;\n\n/**\n * Enum value \"aws.bedrock\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * AWS Bedrock\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_AWS_BEDROCK = \"aws.bedrock\" as const;\n\n/**\n * Enum value \"az.ai.inference\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Azure AI Inference\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `azure.ai.inference`.\n */\nexport const GEN_AI_SYSTEM_VALUE_AZ_AI_INFERENCE = \"az.ai.inference\" as const;\n\n/**\n * Enum value \"az.ai.openai\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Azure OpenAI\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `azure.ai.openai`.\n */\nexport const GEN_AI_SYSTEM_VALUE_AZ_AI_OPENAI = \"az.ai.openai\" as const;\n\n/**\n * Enum value \"azure.ai.inference\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Azure AI Inference\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_AZURE_AI_INFERENCE = \"azure.ai.inference\" as const;\n\n/**\n * Enum value \"azure.ai.openai\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Azure OpenAI\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_AZURE_AI_OPENAI = \"azure.ai.openai\" as const;\n\n/**\n * Enum value \"cohere\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Cohere\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_COHERE = \"cohere\" as const;\n\n/**\n * Enum value \"deepseek\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * DeepSeek\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_DEEPSEEK = \"deepseek\" as const;\n\n/**\n * Enum value \"gcp.gemini\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Gemini\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_GCP_GEMINI = \"gcp.gemini\" as const;\n\n/**\n * Enum value \"gcp.gen_ai\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Any Google generative AI endpoint\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_GCP_GEN_AI = \"gcp.gen_ai\" as const;\n\n/**\n * Enum value \"gcp.vertex_ai\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Vertex AI\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_GCP_VERTEX_AI = \"gcp.vertex_ai\" as const;\n\n/**\n * Enum value \"gemini\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Gemini\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `gcp.gemini`.\n */\nexport const GEN_AI_SYSTEM_VALUE_GEMINI = \"gemini\" as const;\n\n/**\n * Enum value \"groq\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Groq\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_GROQ = \"groq\" as const;\n\n/**\n * Enum value \"ibm.watsonx.ai\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * IBM Watsonx AI\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_IBM_WATSONX_AI = \"ibm.watsonx.ai\" as const;\n\n/**\n * Enum value \"mistral_ai\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Mistral AI\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_MISTRAL_AI = \"mistral_ai\" as const;\n\n/**\n * Enum value \"openai\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * OpenAI\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_OPENAI = \"openai\" as const;\n\n/**\n * Enum value \"perplexity\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Perplexity\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_PERPLEXITY = \"perplexity\" as const;\n\n/**\n * Enum value \"vertex_ai\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * Vertex AI\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `gcp.vertex_ai`.\n */\nexport const GEN_AI_SYSTEM_VALUE_VERTEX_AI = \"vertex_ai\" as const;\n\n/**\n * Enum value \"xai\" for attribute {@link ATTR_GEN_AI_SYSTEM}.\n *\n * xAI\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_SYSTEM_VALUE_XAI = \"xai\" as const;\n\n/**\n * The system message or instructions provided to the GenAI model separately from the chat history.\n *\n * @example [\n * {\n * \"type\": \"text\",\n * \"content\": \"You are an Agent that greet users, always use greetings tool to respond\"\n * }\n * ]\n *\n * @example [\n * {\n * \"type\": \"text\",\n * \"content\": \"You are a language translator.\"\n * },\n * {\n * \"type\": \"text\",\n * \"content\": \"Your mission is to translate text in English to French.\"\n * }\n * ]\n *\n * @note This attribute **SHOULD** be used when the corresponding provider or API\n * allows to provide system instructions or messages separately from the\n * chat history.\n *\n * Instructions that are part of the chat history **SHOULD** be recorded in\n * `gen_ai.input.messages` attribute instead.\n *\n * Instrumentations **MUST** follow [System instructions JSON schema](/docs/gen-ai/gen-ai-system-instructions.json).\n *\n * When recorded on spans, it **MAY** be recorded as a JSON string if structured\n * format is not supported and **SHOULD** be recorded in structured form otherwise.\n *\n * Instrumentations **MAY** provide a way for users to filter or truncate\n * system instructions.\n *\n * > [!Warning]\n * > This attribute may contain sensitive information.\n *\n * See [Recording content on attributes](/docs/gen-ai/gen-ai-spans.md#recording-content-on-attributes)\n * section for more details.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_SYSTEM_INSTRUCTIONS = 'gen_ai.system_instructions' as const;\n\n/**\n * The type of token being counted.\n *\n * @example input\n * @example output\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_TOKEN_TYPE = 'gen_ai.token.type' as const;\n\n/**\n * Enum value \"input\" for attribute {@link ATTR_GEN_AI_TOKEN_TYPE}.\n *\n * Input tokens (prompt, input, etc.)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_TOKEN_TYPE_VALUE_INPUT = \"input\" as const;\n\n/**\n * Enum value \"output\" for attribute {@link ATTR_GEN_AI_TOKEN_TYPE}.\n *\n * Output tokens (completion, response, etc.)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `output`.\n */\nexport const GEN_AI_TOKEN_TYPE_VALUE_COMPLETION = \"output\" as const;\n\n/**\n * Enum value \"output\" for attribute {@link ATTR_GEN_AI_TOKEN_TYPE}.\n *\n * Output tokens (completion, response, etc.)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEN_AI_TOKEN_TYPE_VALUE_OUTPUT = \"output\" as const;\n\n/**\n * Parameters passed to the tool call.\n *\n * @example {\n * \"location\": \"San Francisco?\",\n * \"date\": \"2025-10-01\"\n * }\n *\n * @note > [!WARNING]\n *\n * > This attribute may contain sensitive information.\n *\n * It's expected to be an object - in case a serialized string is available\n * to the instrumentation, the instrumentation **SHOULD** do the best effort to\n * deserialize it to an object. When recorded on spans, it **MAY** be recorded as a JSON string if structured format is not supported and **SHOULD** be recorded in structured form otherwise.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_TOOL_CALL_ARGUMENTS = 'gen_ai.tool.call.arguments' as const;\n\n/**\n * The tool call identifier.\n *\n * @example call_mszuSIzqtI65i1wAUOE8w5H4\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_TOOL_CALL_ID = 'gen_ai.tool.call.id' as const;\n\n/**\n * The result returned by the tool call (if any and if execution was successful).\n *\n * @example {\n * \"temperature_range\": {\n * \"high\": 75,\n * \"low\": 60\n * },\n * \"conditions\": \"sunny\"\n * }\n *\n * @note > [!WARNING]\n *\n * > This attribute may contain sensitive information.\n *\n * It's expected to be an object - in case a serialized string is available\n * to the instrumentation, the instrumentation **SHOULD** do the best effort to\n * deserialize it to an object. When recorded on spans, it **MAY** be recorded as a JSON string if structured format is not supported and **SHOULD** be recorded in structured form otherwise.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_TOOL_CALL_RESULT = 'gen_ai.tool.call.result' as const;\n\n/**\n * The list of source system tool definitions available to the GenAI agent or model.\n *\n * @example [\n * {\n * \"type\": \"function\",\n * \"name\": \"get_current_weather\",\n * \"description\": \"Get the current weather in a given location\",\n * \"parameters\": {\n * \"type\": \"object\",\n * \"properties\": {\n * \"location\": {\n * \"type\": \"string\",\n * \"description\": \"The city and state, e.g. San Francisco, CA\"\n * },\n * \"unit\": {\n * \"type\": \"string\",\n * \"enum\": [\n * \"celsius\",\n * \"fahrenheit\"\n * ]\n * }\n * },\n * \"required\": [\n * \"location\",\n * \"unit\"\n * ]\n * }\n * }\n * ]\n *\n * @note The value of this attribute matches source system tool definition format.\n *\n * It's expected to be an array of objects where each object represents a tool definition. In case a serialized string is available\n * to the instrumentation, the instrumentation **SHOULD** do the best effort to\n * deserialize it to an array. When recorded on spans, it **MAY** be recorded as a JSON string if structured format is not supported and **SHOULD** be recorded in structured form otherwise.\n *\n * Since this attribute could be large, it's NOT **RECOMMENDED** to populate\n * it by default. Instrumentations **MAY** provide a way to enable\n * populating this attribute.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_TOOL_DEFINITIONS = 'gen_ai.tool.definitions' as const;\n\n/**\n * The tool description.\n *\n * @example Multiply two numbers\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_TOOL_DESCRIPTION = 'gen_ai.tool.description' as const;\n\n/**\n * Name of the tool utilized by the agent.\n *\n * @example Flights\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_TOOL_NAME = 'gen_ai.tool.name' as const;\n\n/**\n * Type of the tool utilized by the agent\n *\n * @example function\n * @example extension\n * @example datastore\n *\n * @note Extension: A tool executed on the agent-side to directly call external APIs, bridging the gap between the agent and real-world systems.\n * Agent-side operations involve actions that are performed by the agent on the server or within the agent's controlled environment.\n * Function: A tool executed on the client-side, where the agent generates parameters for a predefined function, and the client executes the logic.\n * Client-side operations are actions taken on the user's end or within the client application.\n * Datastore: A tool used by the agent to access and query structured or unstructured external data for retrieval-augmented tasks or knowledge updates.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_TOOL_TYPE = 'gen_ai.tool.type' as const;\n\n/**\n * Deprecated, use `gen_ai.usage.output_tokens` instead.\n *\n * @example 42\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `gen_ai.usage.output_tokens`.\n */\nexport const ATTR_GEN_AI_USAGE_COMPLETION_TOKENS = 'gen_ai.usage.completion_tokens' as const;\n\n/**\n * The number of tokens used in the GenAI input (prompt).\n *\n * @example 100\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_USAGE_INPUT_TOKENS = 'gen_ai.usage.input_tokens' as const;\n\n/**\n * The number of tokens used in the GenAI response (completion).\n *\n * @example 180\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEN_AI_USAGE_OUTPUT_TOKENS = 'gen_ai.usage.output_tokens' as const;\n\n/**\n * Deprecated, use `gen_ai.usage.input_tokens` instead.\n *\n * @example 42\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `gen_ai.usage.input_tokens`.\n */\nexport const ATTR_GEN_AI_USAGE_PROMPT_TOKENS = 'gen_ai.usage.prompt_tokens' as const;\n\n/**\n * Two-letter code representing continent’s name.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEO_CONTINENT_CODE = 'geo.continent.code' as const;\n\n/**\n * Enum value \"AF\" for attribute {@link ATTR_GEO_CONTINENT_CODE}.\n *\n * Africa\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEO_CONTINENT_CODE_VALUE_AF = \"AF\" as const;\n\n/**\n * Enum value \"AN\" for attribute {@link ATTR_GEO_CONTINENT_CODE}.\n *\n * Antarctica\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEO_CONTINENT_CODE_VALUE_AN = \"AN\" as const;\n\n/**\n * Enum value \"AS\" for attribute {@link ATTR_GEO_CONTINENT_CODE}.\n *\n * Asia\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEO_CONTINENT_CODE_VALUE_AS = \"AS\" as const;\n\n/**\n * Enum value \"EU\" for attribute {@link ATTR_GEO_CONTINENT_CODE}.\n *\n * Europe\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEO_CONTINENT_CODE_VALUE_EU = \"EU\" as const;\n\n/**\n * Enum value \"NA\" for attribute {@link ATTR_GEO_CONTINENT_CODE}.\n *\n * North America\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEO_CONTINENT_CODE_VALUE_NA = \"NA\" as const;\n\n/**\n * Enum value \"OC\" for attribute {@link ATTR_GEO_CONTINENT_CODE}.\n *\n * Oceania\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEO_CONTINENT_CODE_VALUE_OC = \"OC\" as const;\n\n/**\n * Enum value \"SA\" for attribute {@link ATTR_GEO_CONTINENT_CODE}.\n *\n * South America\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GEO_CONTINENT_CODE_VALUE_SA = \"SA\" as const;\n\n/**\n * Two-letter ISO Country Code ([ISO 3166-1 alpha2](https://wikipedia.org/wiki/ISO_3166-1#Codes)).\n *\n * @example CA\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEO_COUNTRY_ISO_CODE = 'geo.country.iso_code' as const;\n\n/**\n * Locality name. Represents the name of a city, town, village, or similar populated place.\n *\n * @example Montreal\n * @example Berlin\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEO_LOCALITY_NAME = 'geo.locality.name' as const;\n\n/**\n * Latitude of the geo location in [WGS84](https://wikipedia.org/wiki/World_Geodetic_System#WGS84).\n *\n * @example 45.505918\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEO_LOCATION_LAT = 'geo.location.lat' as const;\n\n/**\n * Longitude of the geo location in [WGS84](https://wikipedia.org/wiki/World_Geodetic_System#WGS84).\n *\n * @example -73.61483\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEO_LOCATION_LON = 'geo.location.lon' as const;\n\n/**\n * Postal code associated with the location. Values appropriate for this field may also be known as a postcode or ZIP code and will vary widely from country to country.\n *\n * @example 94040\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEO_POSTAL_CODE = 'geo.postal_code' as const;\n\n/**\n * Region ISO code ([ISO 3166-2](https://wikipedia.org/wiki/ISO_3166-2)).\n *\n * @example CA-QC\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GEO_REGION_ISO_CODE = 'geo.region.iso_code' as const;\n\n/**\n * The type of memory.\n *\n * @example other\n * @example stack\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GO_MEMORY_TYPE = 'go.memory.type' as const;\n\n/**\n * Enum value \"other\" for attribute {@link ATTR_GO_MEMORY_TYPE}.\n *\n * Memory used by the Go runtime, excluding other categories of memory usage described in this enumeration.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GO_MEMORY_TYPE_VALUE_OTHER = \"other\" as const;\n\n/**\n * Enum value \"stack\" for attribute {@link ATTR_GO_MEMORY_TYPE}.\n *\n * Memory allocated from the heap that is reserved for stack space, whether or not it is currently in-use.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GO_MEMORY_TYPE_VALUE_STACK = \"stack\" as const;\n\n/**\n * The GraphQL document being executed.\n *\n * @example \"query findBookById { bookById(id: ?) { name } }\"\n *\n * @note The value may be sanitized to exclude sensitive information.\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GRAPHQL_DOCUMENT = 'graphql.document' as const;\n\n/**\n * The name of the operation being executed.\n *\n * @example \"findBookById\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GRAPHQL_OPERATION_NAME = 'graphql.operation.name' as const;\n\n/**\n * The type of the operation being executed.\n *\n * @example query\n * @example mutation\n * @example subscription\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_GRAPHQL_OPERATION_TYPE = 'graphql.operation.type' as const;\n\n/**\n * Enum value \"mutation\" for attribute {@link ATTR_GRAPHQL_OPERATION_TYPE}.\n *\n * GraphQL mutation\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GRAPHQL_OPERATION_TYPE_VALUE_MUTATION = \"mutation\" as const;\n\n/**\n * Enum value \"query\" for attribute {@link ATTR_GRAPHQL_OPERATION_TYPE}.\n *\n * GraphQL query\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GRAPHQL_OPERATION_TYPE_VALUE_QUERY = \"query\" as const;\n\n/**\n * Enum value \"subscription\" for attribute {@link ATTR_GRAPHQL_OPERATION_TYPE}.\n *\n * GraphQL subscription\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const GRAPHQL_OPERATION_TYPE_VALUE_SUBSCRIPTION = \"subscription\" as const;\n\n/**\n * Unique identifier for the application\n *\n * @example 2daa2797-e42b-4624-9322-ec3f968df4da\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HEROKU_APP_ID = 'heroku.app.id' as const;\n\n/**\n * Commit hash for the current release\n *\n * @example e6134959463efd8966b20e75b913cafe3f5ec\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HEROKU_RELEASE_COMMIT = 'heroku.release.commit' as const;\n\n/**\n * Time and date the release was created\n *\n * @example 2022-10-23T18:00:42Z\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HEROKU_RELEASE_CREATION_TIMESTAMP = 'heroku.release.creation_timestamp' as const;\n\n/**\n * The CPU architecture the host system is running on.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_ARCH = 'host.arch' as const;\n\n/**\n * Enum value \"amd64\" for attribute {@link ATTR_HOST_ARCH}.\n *\n * AMD64\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HOST_ARCH_VALUE_AMD64 = \"amd64\" as const;\n\n/**\n * Enum value \"arm32\" for attribute {@link ATTR_HOST_ARCH}.\n *\n * ARM32\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HOST_ARCH_VALUE_ARM32 = \"arm32\" as const;\n\n/**\n * Enum value \"arm64\" for attribute {@link ATTR_HOST_ARCH}.\n *\n * ARM64\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HOST_ARCH_VALUE_ARM64 = \"arm64\" as const;\n\n/**\n * Enum value \"ia64\" for attribute {@link ATTR_HOST_ARCH}.\n *\n * Itanium\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HOST_ARCH_VALUE_IA64 = \"ia64\" as const;\n\n/**\n * Enum value \"ppc32\" for attribute {@link ATTR_HOST_ARCH}.\n *\n * 32-bit PowerPC\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HOST_ARCH_VALUE_PPC32 = \"ppc32\" as const;\n\n/**\n * Enum value \"ppc64\" for attribute {@link ATTR_HOST_ARCH}.\n *\n * 64-bit PowerPC\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HOST_ARCH_VALUE_PPC64 = \"ppc64\" as const;\n\n/**\n * Enum value \"s390x\" for attribute {@link ATTR_HOST_ARCH}.\n *\n * IBM z/Architecture\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HOST_ARCH_VALUE_S390X = \"s390x\" as const;\n\n/**\n * Enum value \"x86\" for attribute {@link ATTR_HOST_ARCH}.\n *\n * 32-bit x86\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HOST_ARCH_VALUE_X86 = \"x86\" as const;\n\n/**\n * The amount of level 2 memory cache available to the processor (in Bytes).\n *\n * @example 12288000\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_CPU_CACHE_L2_SIZE = 'host.cpu.cache.l2.size' as const;\n\n/**\n * Family or generation of the CPU.\n *\n * @example 6\n * @example PA-RISC 1.1e\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_CPU_FAMILY = 'host.cpu.family' as const;\n\n/**\n * Model identifier. It provides more granular information about the CPU, distinguishing it from other CPUs within the same family.\n *\n * @example 6\n * @example 9000/778/B180L\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_CPU_MODEL_ID = 'host.cpu.model.id' as const;\n\n/**\n * Model designation of the processor.\n *\n * @example 11th Gen Intel(R) Core(TM) i7-1185G7 @ 3.00GHz\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_CPU_MODEL_NAME = 'host.cpu.model.name' as const;\n\n/**\n * Stepping or core revisions.\n *\n * @example 1\n * @example r1p1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_CPU_STEPPING = 'host.cpu.stepping' as const;\n\n/**\n * Processor manufacturer identifier. A maximum 12-character string.\n *\n * @example GenuineIntel\n *\n * @note [CPUID](https://wiki.osdev.org/CPUID) command returns the vendor ID string in EBX, EDX and ECX registers. Writing these to memory in this order results in a 12-character string.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_CPU_VENDOR_ID = 'host.cpu.vendor.id' as const;\n\n/**\n * Unique host ID. For Cloud, this must be the instance_id assigned by the cloud provider. For non-containerized systems, this should be the `machine-id`. See the table below for the sources to use to determine the `machine-id` based on operating system.\n *\n * @example fdbf79e8af94cb7f9e8df36789187052\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_ID = 'host.id' as const;\n\n/**\n * VM image ID or host OS image ID. For Cloud, this value is from the provider.\n *\n * @example ami-07b06b442921831e5\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_IMAGE_ID = 'host.image.id' as const;\n\n/**\n * Name of the VM image or OS install the host was instantiated from.\n *\n * @example infra-ami-eks-worker-node-7d4ec78312\n * @example CentOS-8-x86_64-1905\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_IMAGE_NAME = 'host.image.name' as const;\n\n/**\n * The version string of the VM image or host OS as defined in [Version Attributes](/docs/resource/README.md#version-attributes).\n *\n * @example 0.1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_IMAGE_VERSION = 'host.image.version' as const;\n\n/**\n * Available IP addresses of the host, excluding loopback interfaces.\n *\n * @example [\"192.168.1.140\", \"fe80::abc2:4a28:737a:609e\"]\n *\n * @note IPv4 Addresses **MUST** be specified in dotted-quad notation. IPv6 addresses **MUST** be specified in the [RFC 5952](https://www.rfc-editor.org/rfc/rfc5952.html) format.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_IP = 'host.ip' as const;\n\n/**\n * Available MAC addresses of the host, excluding loopback interfaces.\n *\n * @example [\"AC-DE-48-23-45-67\", \"AC-DE-48-23-45-67-01-9F\"]\n *\n * @note MAC Addresses **MUST** be represented in [IEEE RA hexadecimal form](https://standards.ieee.org/wp-content/uploads/import/documents/tutorials/eui.pdf): as hyphen-separated octets in uppercase hexadecimal form from most to least significant.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_MAC = 'host.mac' as const;\n\n/**\n * Name of the host. On Unix systems, it may contain what the hostname command returns, or the fully qualified hostname, or another name specified by the user.\n *\n * @example opentelemetry-test\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_NAME = 'host.name' as const;\n\n/**\n * Type of host. For Cloud, this must be the machine type.\n *\n * @example n1-standard-1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HOST_TYPE = 'host.type' as const;\n\n/**\n * Deprecated, use `client.address` instead.\n *\n * @example \"83.164.160.102\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `client.address`.\n */\nexport const ATTR_HTTP_CLIENT_IP = 'http.client_ip' as const;\n\n/**\n * State of the HTTP connection in the HTTP connection pool.\n *\n * @example active\n * @example idle\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HTTP_CONNECTION_STATE = 'http.connection.state' as const;\n\n/**\n * Enum value \"active\" for attribute {@link ATTR_HTTP_CONNECTION_STATE}.\n *\n * active state.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HTTP_CONNECTION_STATE_VALUE_ACTIVE = \"active\" as const;\n\n/**\n * Enum value \"idle\" for attribute {@link ATTR_HTTP_CONNECTION_STATE}.\n *\n * idle state.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HTTP_CONNECTION_STATE_VALUE_IDLE = \"idle\" as const;\n\n/**\n * Deprecated, use `network.protocol.name` and `network.protocol.version` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Split into `network.protocol.name` and `network.protocol.version`\n */\nexport const ATTR_HTTP_FLAVOR = 'http.flavor' as const;\n\n/**\n * Enum value \"1.0\" for attribute {@link ATTR_HTTP_FLAVOR}.\n *\n * HTTP/1.0\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HTTP_FLAVOR_VALUE_HTTP_1_0 = \"1.0\" as const;\n\n/**\n * Enum value \"1.1\" for attribute {@link ATTR_HTTP_FLAVOR}.\n *\n * HTTP/1.1\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HTTP_FLAVOR_VALUE_HTTP_1_1 = \"1.1\" as const;\n\n/**\n * Enum value \"2.0\" for attribute {@link ATTR_HTTP_FLAVOR}.\n *\n * HTTP/2\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HTTP_FLAVOR_VALUE_HTTP_2_0 = \"2.0\" as const;\n\n/**\n * Enum value \"3.0\" for attribute {@link ATTR_HTTP_FLAVOR}.\n *\n * HTTP/3\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HTTP_FLAVOR_VALUE_HTTP_3_0 = \"3.0\" as const;\n\n/**\n * Enum value \"QUIC\" for attribute {@link ATTR_HTTP_FLAVOR}.\n *\n * QUIC protocol.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HTTP_FLAVOR_VALUE_QUIC = \"QUIC\" as const;\n\n/**\n * Enum value \"SPDY\" for attribute {@link ATTR_HTTP_FLAVOR}.\n *\n * SPDY protocol.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HTTP_FLAVOR_VALUE_SPDY = \"SPDY\" as const;\n\n/**\n * Deprecated, use one of `server.address`, `client.address` or `http.request.header.host` instead, depending on the usage.\n *\n * @example www.example.org\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by one of `server.address`, `client.address` or `http.request.header.host`, depending on the usage.\n */\nexport const ATTR_HTTP_HOST = 'http.host' as const;\n\n/**\n * Deprecated, use `http.request.method` instead.\n *\n * @example GET\n * @example POST\n * @example HEAD\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `http.request.method`.\n */\nexport const ATTR_HTTP_METHOD = 'http.method' as const;\n\n/**\n * The size of the request payload body in bytes. This is the number of bytes transferred excluding headers and is often, but not always, present as the [Content-Length](https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length) header. For requests using transport encoding, this should be the compressed size.\n *\n * @example 3495\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HTTP_REQUEST_BODY_SIZE = 'http.request.body.size' as const;\n\n/**\n * Enum value \"QUERY\" for attribute {@link ATTR_HTTP_REQUEST_METHOD}.\n *\n * QUERY method.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HTTP_REQUEST_METHOD_VALUE_QUERY = \"QUERY\" as const;\n\n/**\n * The total size of the request in bytes. This should be the total number of bytes sent over the wire, including the request line (HTTP/1.1), framing (HTTP/2 and HTTP/3), headers, and request body if any.\n *\n * @example 1437\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HTTP_REQUEST_SIZE = 'http.request.size' as const;\n\n/**\n * Deprecated, use `http.request.header.content-length` instead.\n *\n * @example 3495\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `http.request.header.content-length`.\n */\nexport const ATTR_HTTP_REQUEST_CONTENT_LENGTH = 'http.request_content_length' as const;\n\n/**\n * Deprecated, use `http.request.body.size` instead.\n *\n * @example 5493\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `http.request.body.size`.\n */\nexport const ATTR_HTTP_REQUEST_CONTENT_LENGTH_UNCOMPRESSED = 'http.request_content_length_uncompressed' as const;\n\n/**\n * The size of the response payload body in bytes. This is the number of bytes transferred excluding headers and is often, but not always, present as the [Content-Length](https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length) header. For requests using transport encoding, this should be the compressed size.\n *\n * @example 3495\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HTTP_RESPONSE_BODY_SIZE = 'http.response.body.size' as const;\n\n/**\n * The total size of the response in bytes. This should be the total number of bytes sent over the wire, including the status line (HTTP/1.1), framing (HTTP/2 and HTTP/3), headers, and response body and trailers if any.\n *\n * @example 1437\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HTTP_RESPONSE_SIZE = 'http.response.size' as const;\n\n/**\n * Deprecated, use `http.response.header.content-length` instead.\n *\n * @example 3495\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `http.response.header.content-length`.\n */\nexport const ATTR_HTTP_RESPONSE_CONTENT_LENGTH = 'http.response_content_length' as const;\n\n/**\n * Deprecated, use `http.response.body.size` instead.\n *\n * @example 5493\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `http.response.body.size`.\n */\nexport const ATTR_HTTP_RESPONSE_CONTENT_LENGTH_UNCOMPRESSED = 'http.response_content_length_uncompressed' as const;\n\n/**\n * Deprecated, use `url.scheme` instead.\n *\n * @example http\n * @example https\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `url.scheme`.\n */\nexport const ATTR_HTTP_SCHEME = 'http.scheme' as const;\n\n/**\n * Deprecated, use `server.address` instead.\n *\n * @example example.com\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `server.address`.\n */\nexport const ATTR_HTTP_SERVER_NAME = 'http.server_name' as const;\n\n/**\n * Deprecated, use `http.response.status_code` instead.\n *\n * @example 200\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `http.response.status_code`.\n */\nexport const ATTR_HTTP_STATUS_CODE = 'http.status_code' as const;\n\n/**\n * Deprecated, use `url.path` and `url.query` instead.\n *\n * @example /search?q=OpenTelemetry#SemConv\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Split to `url.path` and `url.query`.\n */\nexport const ATTR_HTTP_TARGET = 'http.target' as const;\n\n/**\n * Deprecated, use `url.full` instead.\n *\n * @example https://www.foo.bar/search?q=OpenTelemetry#SemConv\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `url.full`.\n */\nexport const ATTR_HTTP_URL = 'http.url' as const;\n\n/**\n * Deprecated, use `user_agent.original` instead.\n *\n * @example CERN-LineMode/2.15 libwww/2.17b3\n * @example Mozilla/5.0 (iPhone; CPU iPhone OS 14_7_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/14.1.2 Mobile/15E148 Safari/604.1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `user_agent.original`.\n */\nexport const ATTR_HTTP_USER_AGENT = 'http.user_agent' as const;\n\n/**\n * Design capacity in Watts-hours or Amper-hours\n *\n * @example 9.3Ah\n * @example 50Wh\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_BATTERY_CAPACITY = 'hw.battery.capacity' as const;\n\n/**\n * Battery [chemistry](https://schemas.dmtf.org/wbem/cim-html/2.31.0/CIM_Battery.html), e.g. Lithium-Ion, Nickel-Cadmium, etc.\n *\n * @example Li-ion\n * @example NiMH\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_BATTERY_CHEMISTRY = 'hw.battery.chemistry' as const;\n\n/**\n * The current state of the battery\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_BATTERY_STATE = 'hw.battery.state' as const;\n\n/**\n * Enum value \"charging\" for attribute {@link ATTR_HW_BATTERY_STATE}.\n *\n * Charging\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_BATTERY_STATE_VALUE_CHARGING = \"charging\" as const;\n\n/**\n * Enum value \"discharging\" for attribute {@link ATTR_HW_BATTERY_STATE}.\n *\n * Discharging\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_BATTERY_STATE_VALUE_DISCHARGING = \"discharging\" as const;\n\n/**\n * BIOS version of the hardware component\n *\n * @example 1.2.3\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_BIOS_VERSION = 'hw.bios_version' as const;\n\n/**\n * Driver version for the hardware component\n *\n * @example 10.2.1-3\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_DRIVER_VERSION = 'hw.driver_version' as const;\n\n/**\n * Type of the enclosure (useful for modular systems)\n *\n * @example Computer\n * @example Storage\n * @example Switch\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_ENCLOSURE_TYPE = 'hw.enclosure.type' as const;\n\n/**\n * Firmware version of the hardware component\n *\n * @example 2.0.1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_FIRMWARE_VERSION = 'hw.firmware_version' as const;\n\n/**\n * Type of task the GPU is performing\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_GPU_TASK = 'hw.gpu.task' as const;\n\n/**\n * Enum value \"decoder\" for attribute {@link ATTR_HW_GPU_TASK}.\n *\n * Decoder\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_GPU_TASK_VALUE_DECODER = \"decoder\" as const;\n\n/**\n * Enum value \"encoder\" for attribute {@link ATTR_HW_GPU_TASK}.\n *\n * Encoder\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_GPU_TASK_VALUE_ENCODER = \"encoder\" as const;\n\n/**\n * Enum value \"general\" for attribute {@link ATTR_HW_GPU_TASK}.\n *\n * General\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_GPU_TASK_VALUE_GENERAL = \"general\" as const;\n\n/**\n * An identifier for the hardware component, unique within the monitored host\n *\n * @example win32battery_battery_testsysa33_1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_ID = 'hw.id' as const;\n\n/**\n * Type of limit for hardware components\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_LIMIT_TYPE = 'hw.limit_type' as const;\n\n/**\n * Enum value \"critical\" for attribute {@link ATTR_HW_LIMIT_TYPE}.\n *\n * Critical\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_LIMIT_TYPE_VALUE_CRITICAL = \"critical\" as const;\n\n/**\n * Enum value \"degraded\" for attribute {@link ATTR_HW_LIMIT_TYPE}.\n *\n * Degraded\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_LIMIT_TYPE_VALUE_DEGRADED = \"degraded\" as const;\n\n/**\n * Enum value \"high.critical\" for attribute {@link ATTR_HW_LIMIT_TYPE}.\n *\n * High Critical\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_LIMIT_TYPE_VALUE_HIGH_CRITICAL = \"high.critical\" as const;\n\n/**\n * Enum value \"high.degraded\" for attribute {@link ATTR_HW_LIMIT_TYPE}.\n *\n * High Degraded\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_LIMIT_TYPE_VALUE_HIGH_DEGRADED = \"high.degraded\" as const;\n\n/**\n * Enum value \"low.critical\" for attribute {@link ATTR_HW_LIMIT_TYPE}.\n *\n * Low Critical\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_LIMIT_TYPE_VALUE_LOW_CRITICAL = \"low.critical\" as const;\n\n/**\n * Enum value \"low.degraded\" for attribute {@link ATTR_HW_LIMIT_TYPE}.\n *\n * Low Degraded\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_LIMIT_TYPE_VALUE_LOW_DEGRADED = \"low.degraded\" as const;\n\n/**\n * Enum value \"max\" for attribute {@link ATTR_HW_LIMIT_TYPE}.\n *\n * Maximum\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_LIMIT_TYPE_VALUE_MAX = \"max\" as const;\n\n/**\n * Enum value \"throttled\" for attribute {@link ATTR_HW_LIMIT_TYPE}.\n *\n * Throttled\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_LIMIT_TYPE_VALUE_THROTTLED = \"throttled\" as const;\n\n/**\n * Enum value \"turbo\" for attribute {@link ATTR_HW_LIMIT_TYPE}.\n *\n * Turbo\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_LIMIT_TYPE_VALUE_TURBO = \"turbo\" as const;\n\n/**\n * RAID Level of the logical disk\n *\n * @example RAID0+1\n * @example RAID5\n * @example RAID10\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_LOGICAL_DISK_RAID_LEVEL = 'hw.logical_disk.raid_level' as const;\n\n/**\n * State of the logical disk space usage\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_LOGICAL_DISK_STATE = 'hw.logical_disk.state' as const;\n\n/**\n * Enum value \"free\" for attribute {@link ATTR_HW_LOGICAL_DISK_STATE}.\n *\n * Free\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_LOGICAL_DISK_STATE_VALUE_FREE = \"free\" as const;\n\n/**\n * Enum value \"used\" for attribute {@link ATTR_HW_LOGICAL_DISK_STATE}.\n *\n * Used\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_LOGICAL_DISK_STATE_VALUE_USED = \"used\" as const;\n\n/**\n * Type of the memory module\n *\n * @example DDR4\n * @example DDR5\n * @example LPDDR5\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_MEMORY_TYPE = 'hw.memory.type' as const;\n\n/**\n * Descriptive model name of the hardware component\n *\n * @example PERC H740P\n * @example Intel(R) Core(TM) i7-10700K\n * @example Dell XPS 15 Battery\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_MODEL = 'hw.model' as const;\n\n/**\n * An easily-recognizable name for the hardware component\n *\n * @example eth0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_NAME = 'hw.name' as const;\n\n/**\n * Logical addresses of the adapter (e.g. IP address, or WWPN)\n *\n * @example [\"172.16.8.21\", \"57.11.193.42\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_NETWORK_LOGICAL_ADDRESSES = 'hw.network.logical_addresses' as const;\n\n/**\n * Physical address of the adapter (e.g. MAC address, or WWNN)\n *\n * @example 00-90-F5-E9-7B-36\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_NETWORK_PHYSICAL_ADDRESS = 'hw.network.physical_address' as const;\n\n/**\n * Unique identifier of the parent component (typically the `hw.id` attribute of the enclosure, or disk controller)\n *\n * @example dellStorage_perc_0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_PARENT = 'hw.parent' as const;\n\n/**\n * [S.M.A.R.T.](https://wikipedia.org/wiki/S.M.A.R.T.) (Self-Monitoring, Analysis, and Reporting Technology) attribute of the physical disk\n *\n * @example Spin Retry Count\n * @example Seek Error Rate\n * @example Raw Read Error Rate\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_PHYSICAL_DISK_SMART_ATTRIBUTE = 'hw.physical_disk.smart_attribute' as const;\n\n/**\n * State of the physical disk endurance utilization\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_PHYSICAL_DISK_STATE = 'hw.physical_disk.state' as const;\n\n/**\n * Enum value \"remaining\" for attribute {@link ATTR_HW_PHYSICAL_DISK_STATE}.\n *\n * Remaining\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_PHYSICAL_DISK_STATE_VALUE_REMAINING = \"remaining\" as const;\n\n/**\n * Type of the physical disk\n *\n * @example HDD\n * @example SSD\n * @example 10K\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_PHYSICAL_DISK_TYPE = 'hw.physical_disk.type' as const;\n\n/**\n * Location of the sensor\n *\n * @example cpu0\n * @example ps1\n * @example INLET\n * @example CPU0_DIE\n * @example AMBIENT\n * @example MOTHERBOARD\n * @example PS0 V3_3\n * @example MAIN_12V\n * @example CPU_VCORE\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_SENSOR_LOCATION = 'hw.sensor_location' as const;\n\n/**\n * Serial number of the hardware component\n *\n * @example CNFCP0123456789\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_SERIAL_NUMBER = 'hw.serial_number' as const;\n\n/**\n * The current state of the component\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_STATE = 'hw.state' as const;\n\n/**\n * Enum value \"degraded\" for attribute {@link ATTR_HW_STATE}.\n *\n * Degraded\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_STATE_VALUE_DEGRADED = \"degraded\" as const;\n\n/**\n * Enum value \"failed\" for attribute {@link ATTR_HW_STATE}.\n *\n * Failed\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_STATE_VALUE_FAILED = \"failed\" as const;\n\n/**\n * Enum value \"needs_cleaning\" for attribute {@link ATTR_HW_STATE}.\n *\n * Needs Cleaning\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_STATE_VALUE_NEEDS_CLEANING = \"needs_cleaning\" as const;\n\n/**\n * Enum value \"ok\" for attribute {@link ATTR_HW_STATE}.\n *\n * OK\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_STATE_VALUE_OK = \"ok\" as const;\n\n/**\n * Enum value \"predicted_failure\" for attribute {@link ATTR_HW_STATE}.\n *\n * Predicted Failure\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_STATE_VALUE_PREDICTED_FAILURE = \"predicted_failure\" as const;\n\n/**\n * Type of tape drive operation\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_TAPE_DRIVE_OPERATION_TYPE = 'hw.tape_drive.operation_type' as const;\n\n/**\n * Enum value \"clean\" for attribute {@link ATTR_HW_TAPE_DRIVE_OPERATION_TYPE}.\n *\n * Clean\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TAPE_DRIVE_OPERATION_TYPE_VALUE_CLEAN = \"clean\" as const;\n\n/**\n * Enum value \"mount\" for attribute {@link ATTR_HW_TAPE_DRIVE_OPERATION_TYPE}.\n *\n * Mount\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TAPE_DRIVE_OPERATION_TYPE_VALUE_MOUNT = \"mount\" as const;\n\n/**\n * Enum value \"unmount\" for attribute {@link ATTR_HW_TAPE_DRIVE_OPERATION_TYPE}.\n *\n * Unmount\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TAPE_DRIVE_OPERATION_TYPE_VALUE_UNMOUNT = \"unmount\" as const;\n\n/**\n * Type of the component\n *\n * @note Describes the category of the hardware component for which `hw.state` is being reported. For example, `hw.type=temperature` along with `hw.state=degraded` would indicate that the temperature of the hardware component has been reported as `degraded`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_TYPE = 'hw.type' as const;\n\n/**\n * Enum value \"battery\" for attribute {@link ATTR_HW_TYPE}.\n *\n * Battery\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_BATTERY = \"battery\" as const;\n\n/**\n * Enum value \"cpu\" for attribute {@link ATTR_HW_TYPE}.\n *\n * CPU\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_CPU = \"cpu\" as const;\n\n/**\n * Enum value \"disk_controller\" for attribute {@link ATTR_HW_TYPE}.\n *\n * Disk controller\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_DISK_CONTROLLER = \"disk_controller\" as const;\n\n/**\n * Enum value \"enclosure\" for attribute {@link ATTR_HW_TYPE}.\n *\n * Enclosure\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_ENCLOSURE = \"enclosure\" as const;\n\n/**\n * Enum value \"fan\" for attribute {@link ATTR_HW_TYPE}.\n *\n * Fan\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_FAN = \"fan\" as const;\n\n/**\n * Enum value \"gpu\" for attribute {@link ATTR_HW_TYPE}.\n *\n * GPU\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_GPU = \"gpu\" as const;\n\n/**\n * Enum value \"logical_disk\" for attribute {@link ATTR_HW_TYPE}.\n *\n * Logical disk\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_LOGICAL_DISK = \"logical_disk\" as const;\n\n/**\n * Enum value \"memory\" for attribute {@link ATTR_HW_TYPE}.\n *\n * Memory\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_MEMORY = \"memory\" as const;\n\n/**\n * Enum value \"network\" for attribute {@link ATTR_HW_TYPE}.\n *\n * Network\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_NETWORK = \"network\" as const;\n\n/**\n * Enum value \"physical_disk\" for attribute {@link ATTR_HW_TYPE}.\n *\n * Physical disk\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_PHYSICAL_DISK = \"physical_disk\" as const;\n\n/**\n * Enum value \"power_supply\" for attribute {@link ATTR_HW_TYPE}.\n *\n * Power supply\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_POWER_SUPPLY = \"power_supply\" as const;\n\n/**\n * Enum value \"tape_drive\" for attribute {@link ATTR_HW_TYPE}.\n *\n * Tape drive\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_TAPE_DRIVE = \"tape_drive\" as const;\n\n/**\n * Enum value \"temperature\" for attribute {@link ATTR_HW_TYPE}.\n *\n * Temperature\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_TEMPERATURE = \"temperature\" as const;\n\n/**\n * Enum value \"voltage\" for attribute {@link ATTR_HW_TYPE}.\n *\n * Voltage\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const HW_TYPE_VALUE_VOLTAGE = \"voltage\" as const;\n\n/**\n * Vendor name of the hardware component\n *\n * @example Dell\n * @example HP\n * @example Intel\n * @example AMD\n * @example LSI\n * @example Lenovo\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_HW_VENDOR = 'hw.vendor' as const;\n\n/**\n * This attribute represents the state of the application.\n *\n * @note The iOS lifecycle states are defined in the [UIApplicationDelegate documentation](https://developer.apple.com/documentation/uikit/uiapplicationdelegate), and from which the `OS terminology` column values are derived.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_IOS_APP_STATE = 'ios.app.state' as const;\n\n/**\n * Enum value \"active\" for attribute {@link ATTR_IOS_APP_STATE}.\n *\n * The app has become `active`. Associated with UIKit notification `applicationDidBecomeActive`.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const IOS_APP_STATE_VALUE_ACTIVE = \"active\" as const;\n\n/**\n * Enum value \"background\" for attribute {@link ATTR_IOS_APP_STATE}.\n *\n * The app is now in the background. This value is associated with UIKit notification `applicationDidEnterBackground`.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const IOS_APP_STATE_VALUE_BACKGROUND = \"background\" as const;\n\n/**\n * Enum value \"foreground\" for attribute {@link ATTR_IOS_APP_STATE}.\n *\n * The app is now in the foreground. This value is associated with UIKit notification `applicationWillEnterForeground`.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const IOS_APP_STATE_VALUE_FOREGROUND = \"foreground\" as const;\n\n/**\n * Enum value \"inactive\" for attribute {@link ATTR_IOS_APP_STATE}.\n *\n * The app is now `inactive`. Associated with UIKit notification `applicationWillResignActive`.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const IOS_APP_STATE_VALUE_INACTIVE = \"inactive\" as const;\n\n/**\n * Enum value \"terminate\" for attribute {@link ATTR_IOS_APP_STATE}.\n *\n * The app is about to terminate. Associated with UIKit notification `applicationWillTerminate`.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const IOS_APP_STATE_VALUE_TERMINATE = \"terminate\" as const;\n\n/**\n * Deprecated. Use the `ios.app.state` attribute.\n *\n * @note The iOS lifecycle states are defined in the [UIApplicationDelegate documentation](https://developer.apple.com/documentation/uikit/uiapplicationdelegate), and from which the `OS terminology` column values are derived.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `ios.app.state`.\n */\nexport const ATTR_IOS_STATE = 'ios.state' as const;\n\n/**\n * Enum value \"active\" for attribute {@link ATTR_IOS_STATE}.\n *\n * The app has become `active`. Associated with UIKit notification `applicationDidBecomeActive`.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const IOS_STATE_VALUE_ACTIVE = \"active\" as const;\n\n/**\n * Enum value \"background\" for attribute {@link ATTR_IOS_STATE}.\n *\n * The app is now in the background. This value is associated with UIKit notification `applicationDidEnterBackground`.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const IOS_STATE_VALUE_BACKGROUND = \"background\" as const;\n\n/**\n * Enum value \"foreground\" for attribute {@link ATTR_IOS_STATE}.\n *\n * The app is now in the foreground. This value is associated with UIKit notification `applicationWillEnterForeground`.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const IOS_STATE_VALUE_FOREGROUND = \"foreground\" as const;\n\n/**\n * Enum value \"inactive\" for attribute {@link ATTR_IOS_STATE}.\n *\n * The app is now `inactive`. Associated with UIKit notification `applicationWillResignActive`.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const IOS_STATE_VALUE_INACTIVE = \"inactive\" as const;\n\n/**\n * Enum value \"terminate\" for attribute {@link ATTR_IOS_STATE}.\n *\n * The app is about to terminate. Associated with UIKit notification `applicationWillTerminate`.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const IOS_STATE_VALUE_TERMINATE = \"terminate\" as const;\n\n/**\n * Protocol version, as specified in the `jsonrpc` property of the request and its corresponding response.\n *\n * @example 2.0\n * @example 1.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_JSONRPC_PROTOCOL_VERSION = 'jsonrpc.protocol.version' as const;\n\n/**\n * A string representation of the `id` property of the request and its corresponding response.\n *\n * @example 10\n * @example request-7\n *\n * @note Under the [JSON-RPC specification](https://www.jsonrpc.org/specification), the `id` property may be a string, number, null, or omitted entirely. When omitted, the request is treated as a notification. Using `null` is not equivalent to omitting the `id`, but it is discouraged.\n * Instrumentations **SHOULD NOT** capture this attribute when the `id` is `null` or omitted.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_JSONRPC_REQUEST_ID = 'jsonrpc.request.id' as const;\n\n/**\n * Name of the buffer pool.\n *\n * @example mapped\n * @example direct\n *\n * @note Pool names are generally obtained via [BufferPoolMXBean#getName()](https://docs.oracle.com/en/java/javase/11/docs/api/java.management/java/lang/management/BufferPoolMXBean.html#getName()).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_JVM_BUFFER_POOL_NAME = 'jvm.buffer.pool.name' as const;\n\n/**\n * Name of the garbage collector cause.\n *\n * @example System.gc()\n * @example Allocation Failure\n *\n * @note Garbage collector cause is generally obtained via [GarbageCollectionNotificationInfo#getGcCause()](https://docs.oracle.com/en/java/javase/11/docs/api/jdk.management/com/sun/management/GarbageCollectionNotificationInfo.html#getGcCause()).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_JVM_GC_CAUSE = 'jvm.gc.cause' as const;\n\n/**\n * The name of the cluster.\n *\n * @example opentelemetry-cluster\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_CLUSTER_NAME = 'k8s.cluster.name' as const;\n\n/**\n * A pseudo-ID for the cluster, set to the UID of the `kube-system` namespace.\n *\n * @example 218fc5a9-a5f1-4b54-aa05-46717d0ab26d\n *\n * @note K8s doesn't have support for obtaining a cluster ID. If this is ever\n * added, we will recommend collecting the `k8s.cluster.uid` through the\n * official APIs. In the meantime, we are able to use the `uid` of the\n * `kube-system` namespace as a proxy for cluster ID. Read on for the\n * rationale.\n *\n * Every object created in a K8s cluster is assigned a distinct UID. The\n * `kube-system` namespace is used by Kubernetes itself and will exist\n * for the lifetime of the cluster. Using the `uid` of the `kube-system`\n * namespace is a reasonable proxy for the K8s ClusterID as it will only\n * change if the cluster is rebuilt. Furthermore, Kubernetes UIDs are\n * UUIDs as standardized by\n * [ISO/IEC 9834-8 and ITU-T X.667](https://www.itu.int/ITU-T/studygroups/com17/oid.html).\n * Which states:\n *\n * > If generated according to one of the mechanisms defined in Rec.\n * > ITU-T X.667 | ISO/IEC 9834-8, a UUID is either guaranteed to be\n * > different from all other UUIDs generated before 3603 A.D., or is\n * > extremely likely to be different (depending on the mechanism chosen).\n *\n * Therefore, UIDs between clusters should be extremely unlikely to\n * conflict.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_CLUSTER_UID = 'k8s.cluster.uid' as const;\n\n/**\n * The name of the Container from Pod specification, must be unique within a Pod. Container runtime usually uses different globally unique name (`container.name`).\n *\n * @example redis\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_CONTAINER_NAME = 'k8s.container.name' as const;\n\n/**\n * Number of times the container was restarted. This attribute can be used to identify a particular container (running or stopped) within a container spec.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_CONTAINER_RESTART_COUNT = 'k8s.container.restart_count' as const;\n\n/**\n * Last terminated reason of the Container.\n *\n * @example Evicted\n * @example Error\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_CONTAINER_STATUS_LAST_TERMINATED_REASON = 'k8s.container.status.last_terminated_reason' as const;\n\n/**\n * The reason for the container state. Corresponds to the `reason` field of the: [K8s ContainerStateWaiting](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#containerstatewaiting-v1-core) or [K8s ContainerStateTerminated](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#containerstateterminated-v1-core)\n *\n * @example ContainerCreating\n * @example CrashLoopBackOff\n * @example CreateContainerConfigError\n * @example ErrImagePull\n * @example ImagePullBackOff\n * @example OOMKilled\n * @example Completed\n * @example Error\n * @example ContainerCannotRun\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_CONTAINER_STATUS_REASON = 'k8s.container.status.reason' as const;\n\n/**\n * Enum value \"Completed\" for attribute {@link ATTR_K8S_CONTAINER_STATUS_REASON}.\n *\n * The container has completed execution.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_CONTAINER_STATUS_REASON_VALUE_COMPLETED = \"Completed\" as const;\n\n/**\n * Enum value \"ContainerCannotRun\" for attribute {@link ATTR_K8S_CONTAINER_STATUS_REASON}.\n *\n * The container cannot run.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_CONTAINER_STATUS_REASON_VALUE_CONTAINER_CANNOT_RUN = \"ContainerCannotRun\" as const;\n\n/**\n * Enum value \"ContainerCreating\" for attribute {@link ATTR_K8S_CONTAINER_STATUS_REASON}.\n *\n * The container is being created.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_CONTAINER_STATUS_REASON_VALUE_CONTAINER_CREATING = \"ContainerCreating\" as const;\n\n/**\n * Enum value \"CrashLoopBackOff\" for attribute {@link ATTR_K8S_CONTAINER_STATUS_REASON}.\n *\n * The container is in a crash loop back off state.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_CONTAINER_STATUS_REASON_VALUE_CRASH_LOOP_BACK_OFF = \"CrashLoopBackOff\" as const;\n\n/**\n * Enum value \"CreateContainerConfigError\" for attribute {@link ATTR_K8S_CONTAINER_STATUS_REASON}.\n *\n * There was an error creating the container configuration.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_CONTAINER_STATUS_REASON_VALUE_CREATE_CONTAINER_CONFIG_ERROR = \"CreateContainerConfigError\" as const;\n\n/**\n * Enum value \"ErrImagePull\" for attribute {@link ATTR_K8S_CONTAINER_STATUS_REASON}.\n *\n * There was an error pulling the container image.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_CONTAINER_STATUS_REASON_VALUE_ERR_IMAGE_PULL = \"ErrImagePull\" as const;\n\n/**\n * Enum value \"Error\" for attribute {@link ATTR_K8S_CONTAINER_STATUS_REASON}.\n *\n * There was an error with the container.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_CONTAINER_STATUS_REASON_VALUE_ERROR = \"Error\" as const;\n\n/**\n * Enum value \"ImagePullBackOff\" for attribute {@link ATTR_K8S_CONTAINER_STATUS_REASON}.\n *\n * The container image pull is in back off state.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_CONTAINER_STATUS_REASON_VALUE_IMAGE_PULL_BACK_OFF = \"ImagePullBackOff\" as const;\n\n/**\n * Enum value \"OOMKilled\" for attribute {@link ATTR_K8S_CONTAINER_STATUS_REASON}.\n *\n * The container was killed due to out of memory.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_CONTAINER_STATUS_REASON_VALUE_OOM_KILLED = \"OOMKilled\" as const;\n\n/**\n * The state of the container. [K8s ContainerState](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#containerstate-v1-core)\n *\n * @example terminated\n * @example running\n * @example waiting\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_CONTAINER_STATUS_STATE = 'k8s.container.status.state' as const;\n\n/**\n * Enum value \"running\" for attribute {@link ATTR_K8S_CONTAINER_STATUS_STATE}.\n *\n * The container is running.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_CONTAINER_STATUS_STATE_VALUE_RUNNING = \"running\" as const;\n\n/**\n * Enum value \"terminated\" for attribute {@link ATTR_K8S_CONTAINER_STATUS_STATE}.\n *\n * The container has terminated.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_CONTAINER_STATUS_STATE_VALUE_TERMINATED = \"terminated\" as const;\n\n/**\n * Enum value \"waiting\" for attribute {@link ATTR_K8S_CONTAINER_STATUS_STATE}.\n *\n * The container is waiting.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_CONTAINER_STATUS_STATE_VALUE_WAITING = \"waiting\" as const;\n\n/**\n * The cronjob annotation placed on the CronJob, the `<key>` being the annotation name, the value being the annotation value.\n *\n * @example 4\n * @example\n *\n * @note Examples:\n *\n * - An annotation `retries` with value `4` **SHOULD** be recorded as the\n * `k8s.cronjob.annotation.retries` attribute with value `\"4\"`.\n * - An annotation `data` with empty string value **SHOULD** be recorded as\n * the `k8s.cronjob.annotation.data` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_CRONJOB_ANNOTATION = (key: string) => `k8s.cronjob.annotation.${key}`;\n\n/**\n * The label placed on the CronJob, the `<key>` being the label name, the value being the label value.\n *\n * @example weekly\n * @example\n *\n * @note Examples:\n *\n * - A label `type` with value `weekly` **SHOULD** be recorded as the\n * `k8s.cronjob.label.type` attribute with value `\"weekly\"`.\n * - A label `automated` with empty string value **SHOULD** be recorded as\n * the `k8s.cronjob.label.automated` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_CRONJOB_LABEL = (key: string) => `k8s.cronjob.label.${key}`;\n\n/**\n * The name of the CronJob.\n *\n * @example opentelemetry\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_CRONJOB_NAME = 'k8s.cronjob.name' as const;\n\n/**\n * The UID of the CronJob.\n *\n * @example 275ecb36-5aa8-4c2a-9c47-d8bb681b9aff\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_CRONJOB_UID = 'k8s.cronjob.uid' as const;\n\n/**\n * The annotation placed on the DaemonSet, the `<key>` being the annotation name, the value being the annotation value, even if the value is empty.\n *\n * @example 1\n * @example\n *\n * @note\n * Examples:\n *\n * - A label `replicas` with value `1` **SHOULD** be recorded\n * as the `k8s.daemonset.annotation.replicas` attribute with value `\"1\"`.\n * - A label `data` with empty string value **SHOULD** be recorded as\n * the `k8s.daemonset.annotation.data` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_DAEMONSET_ANNOTATION = (key: string) => `k8s.daemonset.annotation.${key}`;\n\n/**\n * The label placed on the DaemonSet, the `<key>` being the label name, the value being the label value, even if the value is empty.\n *\n * @example guestbook\n * @example\n *\n * @note\n * Examples:\n *\n * - A label `app` with value `guestbook` **SHOULD** be recorded\n * as the `k8s.daemonset.label.app` attribute with value `\"guestbook\"`.\n * - A label `data` with empty string value **SHOULD** be recorded as\n * the `k8s.daemonset.label.injected` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_DAEMONSET_LABEL = (key: string) => `k8s.daemonset.label.${key}`;\n\n/**\n * The name of the DaemonSet.\n *\n * @example opentelemetry\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_DAEMONSET_NAME = 'k8s.daemonset.name' as const;\n\n/**\n * The UID of the DaemonSet.\n *\n * @example 275ecb36-5aa8-4c2a-9c47-d8bb681b9aff\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_DAEMONSET_UID = 'k8s.daemonset.uid' as const;\n\n/**\n * The annotation placed on the Deployment, the `<key>` being the annotation name, the value being the annotation value, even if the value is empty.\n *\n * @example 1\n * @example\n *\n * @note\n * Examples:\n *\n * - A label `replicas` with value `1` **SHOULD** be recorded\n * as the `k8s.deployment.annotation.replicas` attribute with value `\"1\"`.\n * - A label `data` with empty string value **SHOULD** be recorded as\n * the `k8s.deployment.annotation.data` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_DEPLOYMENT_ANNOTATION = (key: string) => `k8s.deployment.annotation.${key}`;\n\n/**\n * The label placed on the Deployment, the `<key>` being the label name, the value being the label value, even if the value is empty.\n *\n * @example guestbook\n * @example\n *\n * @note\n * Examples:\n *\n * - A label `replicas` with value `0` **SHOULD** be recorded\n * as the `k8s.deployment.label.app` attribute with value `\"guestbook\"`.\n * - A label `injected` with empty string value **SHOULD** be recorded as\n * the `k8s.deployment.label.injected` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_DEPLOYMENT_LABEL = (key: string) => `k8s.deployment.label.${key}`;\n\n/**\n * The name of the Deployment.\n *\n * @example opentelemetry\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_DEPLOYMENT_NAME = 'k8s.deployment.name' as const;\n\n/**\n * The UID of the Deployment.\n *\n * @example 275ecb36-5aa8-4c2a-9c47-d8bb681b9aff\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_DEPLOYMENT_UID = 'k8s.deployment.uid' as const;\n\n/**\n * The type of metric source for the horizontal pod autoscaler.\n *\n * @example Resource\n * @example ContainerResource\n *\n * @note This attribute reflects the `type` field of spec.metrics[] in the HPA.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_HPA_METRIC_TYPE = 'k8s.hpa.metric.type' as const;\n\n/**\n * The name of the horizontal pod autoscaler.\n *\n * @example opentelemetry\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_HPA_NAME = 'k8s.hpa.name' as const;\n\n/**\n * The API version of the target resource to scale for the HorizontalPodAutoscaler.\n *\n * @example apps/v1\n * @example autoscaling/v2\n *\n * @note This maps to the `apiVersion` field in the `scaleTargetRef` of the HPA spec.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_HPA_SCALETARGETREF_API_VERSION = 'k8s.hpa.scaletargetref.api_version' as const;\n\n/**\n * The kind of the target resource to scale for the HorizontalPodAutoscaler.\n *\n * @example Deployment\n * @example StatefulSet\n *\n * @note This maps to the `kind` field in the `scaleTargetRef` of the HPA spec.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_HPA_SCALETARGETREF_KIND = 'k8s.hpa.scaletargetref.kind' as const;\n\n/**\n * The name of the target resource to scale for the HorizontalPodAutoscaler.\n *\n * @example my-deployment\n * @example my-statefulset\n *\n * @note This maps to the `name` field in the `scaleTargetRef` of the HPA spec.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_HPA_SCALETARGETREF_NAME = 'k8s.hpa.scaletargetref.name' as const;\n\n/**\n * The UID of the horizontal pod autoscaler.\n *\n * @example 275ecb36-5aa8-4c2a-9c47-d8bb681b9aff\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_HPA_UID = 'k8s.hpa.uid' as const;\n\n/**\n * The size (identifier) of the K8s huge page.\n *\n * @example 2Mi\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_HUGEPAGE_SIZE = 'k8s.hugepage.size' as const;\n\n/**\n * The annotation placed on the Job, the `<key>` being the annotation name, the value being the annotation value, even if the value is empty.\n *\n * @example 1\n * @example\n *\n * @note\n * Examples:\n *\n * - A label `number` with value `1` **SHOULD** be recorded\n * as the `k8s.job.annotation.number` attribute with value `\"1\"`.\n * - A label `data` with empty string value **SHOULD** be recorded as\n * the `k8s.job.annotation.data` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_JOB_ANNOTATION = (key: string) => `k8s.job.annotation.${key}`;\n\n/**\n * The label placed on the Job, the `<key>` being the label name, the value being the label value, even if the value is empty.\n *\n * @example ci\n * @example\n *\n * @note\n * Examples:\n *\n * - A label `jobtype` with value `ci` **SHOULD** be recorded\n * as the `k8s.job.label.jobtype` attribute with value `\"ci\"`.\n * - A label `data` with empty string value **SHOULD** be recorded as\n * the `k8s.job.label.automated` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_JOB_LABEL = (key: string) => `k8s.job.label.${key}`;\n\n/**\n * The name of the Job.\n *\n * @example opentelemetry\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_JOB_NAME = 'k8s.job.name' as const;\n\n/**\n * The UID of the Job.\n *\n * @example 275ecb36-5aa8-4c2a-9c47-d8bb681b9aff\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_JOB_UID = 'k8s.job.uid' as const;\n\n/**\n * The annotation placed on the Namespace, the `<key>` being the annotation name, the value being the annotation value, even if the value is empty.\n *\n * @example 0\n * @example\n *\n * @note\n * Examples:\n *\n * - A label `ttl` with value `0` **SHOULD** be recorded\n * as the `k8s.namespace.annotation.ttl` attribute with value `\"0\"`.\n * - A label `data` with empty string value **SHOULD** be recorded as\n * the `k8s.namespace.annotation.data` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_NAMESPACE_ANNOTATION = (key: string) => `k8s.namespace.annotation.${key}`;\n\n/**\n * The label placed on the Namespace, the `<key>` being the label name, the value being the label value, even if the value is empty.\n *\n * @example default\n * @example\n *\n * @note\n * Examples:\n *\n * - A label `kubernetes.io/metadata.name` with value `default` **SHOULD** be recorded\n * as the `k8s.namespace.label.kubernetes.io/metadata.name` attribute with value `\"default\"`.\n * - A label `data` with empty string value **SHOULD** be recorded as\n * the `k8s.namespace.label.data` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_NAMESPACE_LABEL = (key: string) => `k8s.namespace.label.${key}`;\n\n/**\n * The name of the namespace that the pod is running in.\n *\n * @example default\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_NAMESPACE_NAME = 'k8s.namespace.name' as const;\n\n/**\n * The phase of the K8s namespace.\n *\n * @example active\n * @example terminating\n *\n * @note This attribute aligns with the `phase` field of the\n * [K8s NamespaceStatus](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#namespacestatus-v1-core)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_NAMESPACE_PHASE = 'k8s.namespace.phase' as const;\n\n/**\n * Enum value \"active\" for attribute {@link ATTR_K8S_NAMESPACE_PHASE}.\n *\n * Active namespace phase as described by [K8s API](https://pkg.go.dev/k8s.io/api@v0.31.3/core/v1#NamespacePhase)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_NAMESPACE_PHASE_VALUE_ACTIVE = \"active\" as const;\n\n/**\n * Enum value \"terminating\" for attribute {@link ATTR_K8S_NAMESPACE_PHASE}.\n *\n * Terminating namespace phase as described by [K8s API](https://pkg.go.dev/k8s.io/api@v0.31.3/core/v1#NamespacePhase)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_NAMESPACE_PHASE_VALUE_TERMINATING = \"terminating\" as const;\n\n/**\n * The annotation placed on the Node, the `<key>` being the annotation name, the value being the annotation value, even if the value is empty.\n *\n * @example 0\n * @example\n *\n * @note Examples:\n *\n * - An annotation `node.alpha.kubernetes.io/ttl` with value `0` **SHOULD** be recorded as\n * the `k8s.node.annotation.node.alpha.kubernetes.io/ttl` attribute with value `\"0\"`.\n * - An annotation `data` with empty string value **SHOULD** be recorded as\n * the `k8s.node.annotation.data` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_NODE_ANNOTATION = (key: string) => `k8s.node.annotation.${key}`;\n\n/**\n * The status of the condition, one of True, False, Unknown.\n *\n * @example true\n * @example false\n * @example unknown\n *\n * @note This attribute aligns with the `status` field of the\n * [NodeCondition](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#nodecondition-v1-core)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_NODE_CONDITION_STATUS = 'k8s.node.condition.status' as const;\n\n/**\n * Enum value \"false\" for attribute {@link ATTR_K8S_NODE_CONDITION_STATUS}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_NODE_CONDITION_STATUS_VALUE_CONDITION_FALSE = \"false\" as const;\n\n/**\n * Enum value \"true\" for attribute {@link ATTR_K8S_NODE_CONDITION_STATUS}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_NODE_CONDITION_STATUS_VALUE_CONDITION_TRUE = \"true\" as const;\n\n/**\n * Enum value \"unknown\" for attribute {@link ATTR_K8S_NODE_CONDITION_STATUS}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_NODE_CONDITION_STATUS_VALUE_CONDITION_UNKNOWN = \"unknown\" as const;\n\n/**\n * The condition type of a K8s Node.\n *\n * @example Ready\n * @example DiskPressure\n *\n * @note K8s Node conditions as described\n * by [K8s documentation](https://v1-32.docs.kubernetes.io/docs/reference/node/node-status/#condition).\n *\n * This attribute aligns with the `type` field of the\n * [NodeCondition](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#nodecondition-v1-core)\n *\n * The set of possible values is not limited to those listed here. Managed Kubernetes environments,\n * or custom controllers **MAY** introduce additional node condition types.\n * When this occurs, the exact value as reported by the Kubernetes API **SHOULD** be used.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_NODE_CONDITION_TYPE = 'k8s.node.condition.type' as const;\n\n/**\n * Enum value \"DiskPressure\" for attribute {@link ATTR_K8S_NODE_CONDITION_TYPE}.\n *\n * Pressure exists on the disk size—that is, if the disk capacity is low\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_NODE_CONDITION_TYPE_VALUE_DISK_PRESSURE = \"DiskPressure\" as const;\n\n/**\n * Enum value \"MemoryPressure\" for attribute {@link ATTR_K8S_NODE_CONDITION_TYPE}.\n *\n * Pressure exists on the node memory—that is, if the node memory is low\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_NODE_CONDITION_TYPE_VALUE_MEMORY_PRESSURE = \"MemoryPressure\" as const;\n\n/**\n * Enum value \"NetworkUnavailable\" for attribute {@link ATTR_K8S_NODE_CONDITION_TYPE}.\n *\n * The network for the node is not correctly configured\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_NODE_CONDITION_TYPE_VALUE_NETWORK_UNAVAILABLE = \"NetworkUnavailable\" as const;\n\n/**\n * Enum value \"PIDPressure\" for attribute {@link ATTR_K8S_NODE_CONDITION_TYPE}.\n *\n * Pressure exists on the processes—that is, if there are too many processes on the node\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_NODE_CONDITION_TYPE_VALUE_PID_PRESSURE = \"PIDPressure\" as const;\n\n/**\n * Enum value \"Ready\" for attribute {@link ATTR_K8S_NODE_CONDITION_TYPE}.\n *\n * The node is healthy and ready to accept pods\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_NODE_CONDITION_TYPE_VALUE_READY = \"Ready\" as const;\n\n/**\n * The label placed on the Node, the `<key>` being the label name, the value being the label value, even if the value is empty.\n *\n * @example arm64\n * @example\n *\n * @note Examples:\n *\n * - A label `kubernetes.io/arch` with value `arm64` **SHOULD** be recorded\n * as the `k8s.node.label.kubernetes.io/arch` attribute with value `\"arm64\"`.\n * - A label `data` with empty string value **SHOULD** be recorded as\n * the `k8s.node.label.data` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_NODE_LABEL = (key: string) => `k8s.node.label.${key}`;\n\n/**\n * The name of the Node.\n *\n * @example node-1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_NODE_NAME = 'k8s.node.name' as const;\n\n/**\n * The UID of the Node.\n *\n * @example 1eb3a0c6-0477-4080-a9cb-0cb7db65c6a2\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_NODE_UID = 'k8s.node.uid' as const;\n\n/**\n * The annotation placed on the Pod, the `<key>` being the annotation name, the value being the annotation value.\n *\n * @example true\n * @example x64\n * @example\n *\n * @note Examples:\n *\n * - An annotation `kubernetes.io/enforce-mountable-secrets` with value `true` **SHOULD** be recorded as\n * the `k8s.pod.annotation.kubernetes.io/enforce-mountable-secrets` attribute with value `\"true\"`.\n * - An annotation `mycompany.io/arch` with value `x64` **SHOULD** be recorded as\n * the `k8s.pod.annotation.mycompany.io/arch` attribute with value `\"x64\"`.\n * - An annotation `data` with empty string value **SHOULD** be recorded as\n * the `k8s.pod.annotation.data` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_POD_ANNOTATION = (key: string) => `k8s.pod.annotation.${key}`;\n\n/**\n * Specifies the hostname of the Pod.\n *\n * @example collector-gateway\n *\n * @note The K8s Pod spec has an optional hostname field, which can be used to specify a hostname.\n * Refer to [K8s docs](https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-hostname-and-subdomain-field)\n * for more information about this field.\n *\n * This attribute aligns with the `hostname` field of the\n * [K8s PodSpec](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.34/#podspec-v1-core).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_POD_HOSTNAME = 'k8s.pod.hostname' as const;\n\n/**\n * IP address allocated to the Pod.\n *\n * @example 172.18.0.2\n *\n * @note This attribute aligns with the `podIP` field of the\n * [K8s PodStatus](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.34/#podstatus-v1-core).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_POD_IP = 'k8s.pod.ip' as const;\n\n/**\n * The label placed on the Pod, the `<key>` being the label name, the value being the label value.\n *\n * @example my-app\n * @example x64\n * @example\n *\n * @note Examples:\n *\n * - A label `app` with value `my-app` **SHOULD** be recorded as\n * the `k8s.pod.label.app` attribute with value `\"my-app\"`.\n * - A label `mycompany.io/arch` with value `x64` **SHOULD** be recorded as\n * the `k8s.pod.label.mycompany.io/arch` attribute with value `\"x64\"`.\n * - A label `data` with empty string value **SHOULD** be recorded as\n * the `k8s.pod.label.data` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_POD_LABEL = (key: string) => `k8s.pod.label.${key}`;\n\n/**\n * Deprecated, use `k8s.pod.label` instead.\n *\n * @example my-app\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `k8s.pod.label`.\n */\nexport const ATTR_K8S_POD_LABELS = (key: string) => `k8s.pod.labels.${key}`;\n\n/**\n * The name of the Pod.\n *\n * @example opentelemetry-pod-autoconf\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_POD_NAME = 'k8s.pod.name' as const;\n\n/**\n * The start timestamp of the Pod.\n *\n * @example 2025-12-04T08:41:03Z\n *\n * @note Date and time at which the object was acknowledged by the Kubelet.\n * This is before the Kubelet pulled the container image(s) for the pod.\n *\n * This attribute aligns with the `startTime` field of the\n * [K8s PodStatus](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.34/#podstatus-v1-core),\n * in ISO 8601 (RFC 3339 compatible) format.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_POD_START_TIME = 'k8s.pod.start_time' as const;\n\n/**\n * The phase for the pod. Corresponds to the `phase` field of the: [K8s PodStatus](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.33/#podstatus-v1-core)\n *\n * @example Pending\n * @example Running\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_POD_STATUS_PHASE = 'k8s.pod.status.phase' as const;\n\n/**\n * Enum value \"Failed\" for attribute {@link ATTR_K8S_POD_STATUS_PHASE}.\n *\n * All containers in the pod have terminated, and at least one container has terminated in a failure (exited with a non-zero exit code or was stopped by the system).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_POD_STATUS_PHASE_VALUE_FAILED = \"Failed\" as const;\n\n/**\n * Enum value \"Pending\" for attribute {@link ATTR_K8S_POD_STATUS_PHASE}.\n *\n * The pod has been accepted by the system, but one or more of the containers has not been started. This includes time before being bound to a node, as well as time spent pulling images onto the host.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_POD_STATUS_PHASE_VALUE_PENDING = \"Pending\" as const;\n\n/**\n * Enum value \"Running\" for attribute {@link ATTR_K8S_POD_STATUS_PHASE}.\n *\n * The pod has been bound to a node and all of the containers have been started. At least one container is still running or is in the process of being restarted.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_POD_STATUS_PHASE_VALUE_RUNNING = \"Running\" as const;\n\n/**\n * Enum value \"Succeeded\" for attribute {@link ATTR_K8S_POD_STATUS_PHASE}.\n *\n * All containers in the pod have voluntarily terminated with a container exit code of 0, and the system is not going to restart any of these containers.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_POD_STATUS_PHASE_VALUE_SUCCEEDED = \"Succeeded\" as const;\n\n/**\n * Enum value \"Unknown\" for attribute {@link ATTR_K8S_POD_STATUS_PHASE}.\n *\n * For some reason the state of the pod could not be obtained, typically due to an error in communicating with the host of the pod.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_POD_STATUS_PHASE_VALUE_UNKNOWN = \"Unknown\" as const;\n\n/**\n * The reason for the pod state. Corresponds to the `reason` field of the: [K8s PodStatus](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.33/#podstatus-v1-core)\n *\n * @example Evicted\n * @example NodeAffinity\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_POD_STATUS_REASON = 'k8s.pod.status.reason' as const;\n\n/**\n * Enum value \"Evicted\" for attribute {@link ATTR_K8S_POD_STATUS_REASON}.\n *\n * The pod is evicted.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_POD_STATUS_REASON_VALUE_EVICTED = \"Evicted\" as const;\n\n/**\n * Enum value \"NodeAffinity\" for attribute {@link ATTR_K8S_POD_STATUS_REASON}.\n *\n * The pod is in a status because of its node affinity\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_POD_STATUS_REASON_VALUE_NODE_AFFINITY = \"NodeAffinity\" as const;\n\n/**\n * Enum value \"NodeLost\" for attribute {@link ATTR_K8S_POD_STATUS_REASON}.\n *\n * The reason on a pod when its state cannot be confirmed as kubelet is unresponsive on the node it is (was) running.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_POD_STATUS_REASON_VALUE_NODE_LOST = \"NodeLost\" as const;\n\n/**\n * Enum value \"Shutdown\" for attribute {@link ATTR_K8S_POD_STATUS_REASON}.\n *\n * The node is shutdown\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_POD_STATUS_REASON_VALUE_SHUTDOWN = \"Shutdown\" as const;\n\n/**\n * Enum value \"UnexpectedAdmissionError\" for attribute {@link ATTR_K8S_POD_STATUS_REASON}.\n *\n * The pod was rejected admission to the node because of an error during admission that could not be categorized.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_POD_STATUS_REASON_VALUE_UNEXPECTED_ADMISSION_ERROR = \"UnexpectedAdmissionError\" as const;\n\n/**\n * The UID of the Pod.\n *\n * @example 275ecb36-5aa8-4c2a-9c47-d8bb681b9aff\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_POD_UID = 'k8s.pod.uid' as const;\n\n/**\n * The annotation placed on the ReplicaSet, the `<key>` being the annotation name, the value being the annotation value, even if the value is empty.\n *\n * @example 0\n * @example\n *\n * @note\n * Examples:\n *\n * - A label `replicas` with value `0` **SHOULD** be recorded\n * as the `k8s.replicaset.annotation.replicas` attribute with value `\"0\"`.\n * - A label `data` with empty string value **SHOULD** be recorded as\n * the `k8s.replicaset.annotation.data` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_REPLICASET_ANNOTATION = (key: string) => `k8s.replicaset.annotation.${key}`;\n\n/**\n * The label placed on the ReplicaSet, the `<key>` being the label name, the value being the label value, even if the value is empty.\n *\n * @example guestbook\n * @example\n *\n * @note\n * Examples:\n *\n * - A label `app` with value `guestbook` **SHOULD** be recorded\n * as the `k8s.replicaset.label.app` attribute with value `\"guestbook\"`.\n * - A label `injected` with empty string value **SHOULD** be recorded as\n * the `k8s.replicaset.label.injected` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_REPLICASET_LABEL = (key: string) => `k8s.replicaset.label.${key}`;\n\n/**\n * The name of the ReplicaSet.\n *\n * @example opentelemetry\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_REPLICASET_NAME = 'k8s.replicaset.name' as const;\n\n/**\n * The UID of the ReplicaSet.\n *\n * @example 275ecb36-5aa8-4c2a-9c47-d8bb681b9aff\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_REPLICASET_UID = 'k8s.replicaset.uid' as const;\n\n/**\n * The name of the replication controller.\n *\n * @example opentelemetry\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_REPLICATIONCONTROLLER_NAME = 'k8s.replicationcontroller.name' as const;\n\n/**\n * The UID of the replication controller.\n *\n * @example 275ecb36-5aa8-4c2a-9c47-d8bb681b9aff\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_REPLICATIONCONTROLLER_UID = 'k8s.replicationcontroller.uid' as const;\n\n/**\n * The name of the resource quota.\n *\n * @example opentelemetry\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_RESOURCEQUOTA_NAME = 'k8s.resourcequota.name' as const;\n\n/**\n * The name of the K8s resource a resource quota defines.\n *\n * @example count/replicationcontrollers\n *\n * @note The value for this attribute can be either the full `count/<resource>[.<group>]` string (e.g., count/deployments.apps, count/pods), or, for certain core Kubernetes resources, just the resource name (e.g., pods, services, configmaps). Both forms are supported by Kubernetes for object count quotas. See [Kubernetes Resource Quotas documentation](https://kubernetes.io/docs/concepts/policy/resource-quotas/#quota-on-object-count) for more details.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_RESOURCEQUOTA_RESOURCE_NAME = 'k8s.resourcequota.resource_name' as const;\n\n/**\n * The UID of the resource quota.\n *\n * @example 275ecb36-5aa8-4c2a-9c47-d8bb681b9aff\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_RESOURCEQUOTA_UID = 'k8s.resourcequota.uid' as const;\n\n/**\n * The annotation placed on the StatefulSet, the `<key>` being the annotation name, the value being the annotation value, even if the value is empty.\n *\n * @example 1\n * @example\n *\n * @note\n * Examples:\n *\n * - A label `replicas` with value `1` **SHOULD** be recorded\n * as the `k8s.statefulset.annotation.replicas` attribute with value `\"1\"`.\n * - A label `data` with empty string value **SHOULD** be recorded as\n * the `k8s.statefulset.annotation.data` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_STATEFULSET_ANNOTATION = (key: string) => `k8s.statefulset.annotation.${key}`;\n\n/**\n * The label placed on the StatefulSet, the `<key>` being the label name, the value being the label value, even if the value is empty.\n *\n * @example guestbook\n * @example\n *\n * @note\n * Examples:\n *\n * - A label `replicas` with value `0` **SHOULD** be recorded\n * as the `k8s.statefulset.label.app` attribute with value `\"guestbook\"`.\n * - A label `injected` with empty string value **SHOULD** be recorded as\n * the `k8s.statefulset.label.injected` attribute with value `\"\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_STATEFULSET_LABEL = (key: string) => `k8s.statefulset.label.${key}`;\n\n/**\n * The name of the StatefulSet.\n *\n * @example opentelemetry\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_STATEFULSET_NAME = 'k8s.statefulset.name' as const;\n\n/**\n * The UID of the StatefulSet.\n *\n * @example 275ecb36-5aa8-4c2a-9c47-d8bb681b9aff\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_STATEFULSET_UID = 'k8s.statefulset.uid' as const;\n\n/**\n * The name of K8s [StorageClass](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#storageclass-v1-storage-k8s-io) object.\n *\n * @example gold.storageclass.storage.k8s.io\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_STORAGECLASS_NAME = 'k8s.storageclass.name' as const;\n\n/**\n * The name of the K8s volume.\n *\n * @example volume0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_VOLUME_NAME = 'k8s.volume.name' as const;\n\n/**\n * The type of the K8s volume.\n *\n * @example emptyDir\n * @example persistentVolumeClaim\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_K8S_VOLUME_TYPE = 'k8s.volume.type' as const;\n\n/**\n * Enum value \"configMap\" for attribute {@link ATTR_K8S_VOLUME_TYPE}.\n *\n * A [configMap](https://v1-30.docs.kubernetes.io/docs/concepts/storage/volumes/#configmap) volume\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_VOLUME_TYPE_VALUE_CONFIG_MAP = \"configMap\" as const;\n\n/**\n * Enum value \"downwardAPI\" for attribute {@link ATTR_K8S_VOLUME_TYPE}.\n *\n * A [downwardAPI](https://v1-30.docs.kubernetes.io/docs/concepts/storage/volumes/#downwardapi) volume\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_VOLUME_TYPE_VALUE_DOWNWARD_API = \"downwardAPI\" as const;\n\n/**\n * Enum value \"emptyDir\" for attribute {@link ATTR_K8S_VOLUME_TYPE}.\n *\n * An [emptyDir](https://v1-30.docs.kubernetes.io/docs/concepts/storage/volumes/#emptydir) volume\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_VOLUME_TYPE_VALUE_EMPTY_DIR = \"emptyDir\" as const;\n\n/**\n * Enum value \"local\" for attribute {@link ATTR_K8S_VOLUME_TYPE}.\n *\n * A [local](https://v1-30.docs.kubernetes.io/docs/concepts/storage/volumes/#local) volume\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_VOLUME_TYPE_VALUE_LOCAL = \"local\" as const;\n\n/**\n * Enum value \"persistentVolumeClaim\" for attribute {@link ATTR_K8S_VOLUME_TYPE}.\n *\n * A [persistentVolumeClaim](https://v1-30.docs.kubernetes.io/docs/concepts/storage/volumes/#persistentvolumeclaim) volume\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_VOLUME_TYPE_VALUE_PERSISTENT_VOLUME_CLAIM = \"persistentVolumeClaim\" as const;\n\n/**\n * Enum value \"secret\" for attribute {@link ATTR_K8S_VOLUME_TYPE}.\n *\n * A [secret](https://v1-30.docs.kubernetes.io/docs/concepts/storage/volumes/#secret) volume\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const K8S_VOLUME_TYPE_VALUE_SECRET = \"secret\" as const;\n\n/**\n * The Linux Slab memory state\n *\n * @example reclaimable\n * @example unreclaimable\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `system.memory.linux.slab.state`.\n */\nexport const ATTR_LINUX_MEMORY_SLAB_STATE = 'linux.memory.slab.state' as const;\n\n/**\n * Enum value \"reclaimable\" for attribute {@link ATTR_LINUX_MEMORY_SLAB_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const LINUX_MEMORY_SLAB_STATE_VALUE_RECLAIMABLE = \"reclaimable\" as const;\n\n/**\n * Enum value \"unreclaimable\" for attribute {@link ATTR_LINUX_MEMORY_SLAB_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const LINUX_MEMORY_SLAB_STATE_VALUE_UNRECLAIMABLE = \"unreclaimable\" as const;\n\n/**\n * The basename of the file.\n *\n * @example audit.log\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_LOG_FILE_NAME = 'log.file.name' as const;\n\n/**\n * The basename of the file, with symlinks resolved.\n *\n * @example uuid.log\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_LOG_FILE_NAME_RESOLVED = 'log.file.name_resolved' as const;\n\n/**\n * The full path to the file.\n *\n * @example /var/log/mysql/audit.log\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_LOG_FILE_PATH = 'log.file.path' as const;\n\n/**\n * The full path to the file, with symlinks resolved.\n *\n * @example /var/lib/docker/uuid.log\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_LOG_FILE_PATH_RESOLVED = 'log.file.path_resolved' as const;\n\n/**\n * The stream associated with the log. See below for a list of well-known values.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_LOG_IOSTREAM = 'log.iostream' as const;\n\n/**\n * Enum value \"stderr\" for attribute {@link ATTR_LOG_IOSTREAM}.\n *\n * Events from stderr stream\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const LOG_IOSTREAM_VALUE_STDERR = \"stderr\" as const;\n\n/**\n * Enum value \"stdout\" for attribute {@link ATTR_LOG_IOSTREAM}.\n *\n * Logs from stdout stream\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const LOG_IOSTREAM_VALUE_STDOUT = \"stdout\" as const;\n\n/**\n * The complete original Log Record.\n *\n * @example 77 <86>1 2015-08-06T21:58:59.694Z 192.168.2.133 inactive - - - Something happened\n * @example [INFO] 8/3/24 12:34:56 Something happened\n *\n * @note This value **MAY** be added when processing a Log Record which was originally transmitted as a string or equivalent data type AND the Body field of the Log Record does not contain the same value. (e.g. a syslog or a log record read from a file.)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_LOG_RECORD_ORIGINAL = 'log.record.original' as const;\n\n/**\n * A unique identifier for the Log Record.\n *\n * @example 01ARZ3NDEKTSV4RRFFQ69G5FAV\n *\n * @note If an id is provided, other log records with the same id will be considered duplicates and can be removed safely. This means, that two distinguishable log records **MUST** have different values.\n * The id **MAY** be an [Universally Unique Lexicographically Sortable Identifier (ULID)](https://github.com/ulid/spec), but other identifiers (e.g. UUID) may be used as needed.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_LOG_RECORD_UID = 'log.record.uid' as const;\n\n/**\n * Name of the logical partition that hosts a systems with a mainframe operating system.\n *\n * @example LPAR01\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MAINFRAME_LPAR_NAME = 'mainframe.lpar.name' as const;\n\n/**\n * The name of the request or notification method.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MCP_METHOD_NAME = 'mcp.method.name' as const;\n\n/**\n * Enum value \"completion/complete\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to complete a prompt.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_COMPLETION_COMPLETE = \"completion/complete\" as const;\n\n/**\n * Enum value \"elicitation/create\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request from the server to elicit additional information from the user via the client\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_ELICITATION_CREATE = \"elicitation/create\" as const;\n\n/**\n * Enum value \"initialize\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to initialize the MCP client.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_INITIALIZE = \"initialize\" as const;\n\n/**\n * Enum value \"logging/setLevel\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to set the logging level.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_LOGGING_SET_LEVEL = \"logging/setLevel\" as const;\n\n/**\n * Enum value \"notifications/cancelled\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Notification cancelling a previously-issued request.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_NOTIFICATIONS_CANCELLED = \"notifications/cancelled\" as const;\n\n/**\n * Enum value \"notifications/initialized\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Notification indicating that the MCP client has been initialized.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_NOTIFICATIONS_INITIALIZED = \"notifications/initialized\" as const;\n\n/**\n * Enum value \"notifications/message\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Notification indicating that a message has been received.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_NOTIFICATIONS_MESSAGE = \"notifications/message\" as const;\n\n/**\n * Enum value \"notifications/progress\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Notification indicating the progress for a long-running operation.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_NOTIFICATIONS_PROGRESS = \"notifications/progress\" as const;\n\n/**\n * Enum value \"notifications/prompts/list_changed\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Notification indicating that the list of prompts has changed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_NOTIFICATIONS_PROMPTS_LIST_CHANGED = \"notifications/prompts/list_changed\" as const;\n\n/**\n * Enum value \"notifications/resources/list_changed\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Notification indicating that the list of resources has changed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_NOTIFICATIONS_RESOURCES_LIST_CHANGED = \"notifications/resources/list_changed\" as const;\n\n/**\n * Enum value \"notifications/resources/updated\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Notification indicating that a resource has been updated.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_NOTIFICATIONS_RESOURCES_UPDATED = \"notifications/resources/updated\" as const;\n\n/**\n * Enum value \"notifications/roots/list_changed\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Notification indicating that the list of roots has changed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_NOTIFICATIONS_ROOTS_LIST_CHANGED = \"notifications/roots/list_changed\" as const;\n\n/**\n * Enum value \"notifications/tools/list_changed\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Notification indicating that the list of tools has changed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_NOTIFICATIONS_TOOLS_LIST_CHANGED = \"notifications/tools/list_changed\" as const;\n\n/**\n * Enum value \"ping\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to check that the other party is still alive.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_PING = \"ping\" as const;\n\n/**\n * Enum value \"prompts/get\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to get a prompt.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_PROMPTS_GET = \"prompts/get\" as const;\n\n/**\n * Enum value \"prompts/list\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to list prompts available on server.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_PROMPTS_LIST = \"prompts/list\" as const;\n\n/**\n * Enum value \"resources/list\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to list resources available on server.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_RESOURCES_LIST = \"resources/list\" as const;\n\n/**\n * Enum value \"resources/read\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to read a resource.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_RESOURCES_READ = \"resources/read\" as const;\n\n/**\n * Enum value \"resources/subscribe\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to subscribe to a resource.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_RESOURCES_SUBSCRIBE = \"resources/subscribe\" as const;\n\n/**\n * Enum value \"resources/templates/list\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to list resource templates available on server.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_RESOURCES_TEMPLATES_LIST = \"resources/templates/list\" as const;\n\n/**\n * Enum value \"resources/unsubscribe\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to unsubscribe from resource updates.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_RESOURCES_UNSUBSCRIBE = \"resources/unsubscribe\" as const;\n\n/**\n * Enum value \"roots/list\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to list roots available on server.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_ROOTS_LIST = \"roots/list\" as const;\n\n/**\n * Enum value \"sampling/createMessage\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to create a sampling message.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_SAMPLING_CREATE_MESSAGE = \"sampling/createMessage\" as const;\n\n/**\n * Enum value \"tools/call\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to call a tool.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_TOOLS_CALL = \"tools/call\" as const;\n\n/**\n * Enum value \"tools/list\" for attribute {@link ATTR_MCP_METHOD_NAME}.\n *\n * Request to list tools available on server.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MCP_METHOD_NAME_VALUE_TOOLS_LIST = \"tools/list\" as const;\n\n/**\n * The [version](https://modelcontextprotocol.io/specification/versioning) of the Model Context Protocol used.\n *\n * @example 2025-06-18\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MCP_PROTOCOL_VERSION = 'mcp.protocol.version' as const;\n\n/**\n * The value of the resource uri.\n *\n * @example postgres://database/customers/schema\n * @example file:///home/user/documents/report.pdf\n *\n * @note This is a URI of the resource provided in the following requests or notifications: `resources/read`, `resources/subscribe`, `resources/unsubscribe`, or `notifications/resources/updated`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MCP_RESOURCE_URI = 'mcp.resource.uri' as const;\n\n/**\n * Identifies [MCP session](https://modelcontextprotocol.io/specification/2025-06-18/basic/transports#session-management).\n *\n * @example 191c4850af6c49e08843a3f6c80e5046\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MCP_SESSION_ID = 'mcp.session.id' as const;\n\n/**\n * Deprecated, use `rpc.message.compressed_size` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `rpc.message.compressed_size`.\n */\nexport const ATTR_MESSAGE_COMPRESSED_SIZE = 'message.compressed_size' as const;\n\n/**\n * Deprecated, use `rpc.message.id` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `rpc.message.id`.\n */\nexport const ATTR_MESSAGE_ID = 'message.id' as const;\n\n/**\n * Deprecated, use `rpc.message.type` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `rpc.message.type`.\n */\nexport const ATTR_MESSAGE_TYPE = 'message.type' as const;\n\n/**\n * Enum value \"RECEIVED\" for attribute {@link ATTR_MESSAGE_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGE_TYPE_VALUE_RECEIVED = \"RECEIVED\" as const;\n\n/**\n * Enum value \"SENT\" for attribute {@link ATTR_MESSAGE_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGE_TYPE_VALUE_SENT = \"SENT\" as const;\n\n/**\n * Deprecated, use `rpc.message.uncompressed_size` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `rpc.message.uncompressed_size`.\n */\nexport const ATTR_MESSAGE_UNCOMPRESSED_SIZE = 'message.uncompressed_size' as const;\n\n/**\n * The number of messages sent, received, or processed in the scope of the batching operation.\n *\n * @example 0\n * @example 1\n * @example 2\n *\n * @note Instrumentations **SHOULD NOT** set `messaging.batch.message_count` on spans that operate with a single message. When a messaging client library supports both batch and single-message API for the same operation, instrumentations **SHOULD** use `messaging.batch.message_count` for batching APIs and **SHOULD NOT** use it for single-message APIs.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_BATCH_MESSAGE_COUNT = 'messaging.batch.message_count' as const;\n\n/**\n * A unique identifier for the client that consumes or produces a message.\n *\n * @example client-5\n * @example myhost@8742@s8083jm\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_CLIENT_ID = 'messaging.client.id' as const;\n\n/**\n * The name of the consumer group with which a consumer is associated.\n *\n * @example my-group\n * @example indexer\n *\n * @note Semantic conventions for individual messaging systems **SHOULD** document whether `messaging.consumer.group.name` is applicable and what it means in the context of that system.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_CONSUMER_GROUP_NAME = 'messaging.consumer.group.name' as const;\n\n/**\n * A boolean that is true if the message destination is anonymous (could be unnamed or have auto-generated name).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_DESTINATION_ANONYMOUS = 'messaging.destination.anonymous' as const;\n\n/**\n * The message destination name\n *\n * @example MyQueue\n * @example MyTopic\n *\n * @note Destination name **SHOULD** uniquely identify a specific queue, topic or other entity within the broker. If\n * the broker doesn't have such notion, the destination name **SHOULD** uniquely identify the broker.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_DESTINATION_NAME = 'messaging.destination.name' as const;\n\n/**\n * The identifier of the partition messages are sent to or received from, unique within the `messaging.destination.name`.\n *\n * @example \"1\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_DESTINATION_PARTITION_ID = 'messaging.destination.partition.id' as const;\n\n/**\n * The name of the destination subscription from which a message is consumed.\n *\n * @example subscription-a\n *\n * @note Semantic conventions for individual messaging systems **SHOULD** document whether `messaging.destination.subscription.name` is applicable and what it means in the context of that system.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_DESTINATION_SUBSCRIPTION_NAME = 'messaging.destination.subscription.name' as const;\n\n/**\n * Low cardinality representation of the messaging destination name\n *\n * @example /customers/{customerId}\n *\n * @note Destination names could be constructed from templates. An example would be a destination name involving a user name or product id. Although the destination name in this case is of high cardinality, the underlying template is of low cardinality and can be effectively used for grouping and aggregation.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_DESTINATION_TEMPLATE = 'messaging.destination.template' as const;\n\n/**\n * A boolean that is true if the message destination is temporary and might not exist anymore after messages are processed.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_DESTINATION_TEMPORARY = 'messaging.destination.temporary' as const;\n\n/**\n * Deprecated, no replacement at this time.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Removed. No replacement at this time.\n */\nexport const ATTR_MESSAGING_DESTINATION_PUBLISH_ANONYMOUS = 'messaging.destination_publish.anonymous' as const;\n\n/**\n * Deprecated, no replacement at this time.\n *\n * @example MyQueue\n * @example MyTopic\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Removed. No replacement at this time.\n */\nexport const ATTR_MESSAGING_DESTINATION_PUBLISH_NAME = 'messaging.destination_publish.name' as const;\n\n/**\n * Deprecated, use `messaging.consumer.group.name` instead.\n *\n * @example \"$Default\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `messaging.consumer.group.name`.\n */\nexport const ATTR_MESSAGING_EVENTHUBS_CONSUMER_GROUP = 'messaging.eventhubs.consumer.group' as const;\n\n/**\n * The UTC epoch seconds at which the message has been accepted and stored in the entity.\n *\n * @example 1701393730\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_EVENTHUBS_MESSAGE_ENQUEUED_TIME = 'messaging.eventhubs.message.enqueued_time' as const;\n\n/**\n * The ack deadline in seconds set for the modify ack deadline request.\n *\n * @example 10\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_GCP_PUBSUB_MESSAGE_ACK_DEADLINE = 'messaging.gcp_pubsub.message.ack_deadline' as const;\n\n/**\n * The ack id for a given message.\n *\n * @example \"ack_id\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_GCP_PUBSUB_MESSAGE_ACK_ID = 'messaging.gcp_pubsub.message.ack_id' as const;\n\n/**\n * The delivery attempt for a given message.\n *\n * @example 2\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_GCP_PUBSUB_MESSAGE_DELIVERY_ATTEMPT = 'messaging.gcp_pubsub.message.delivery_attempt' as const;\n\n/**\n * The ordering key for a given message. If the attribute is not present, the message does not have an ordering key.\n *\n * @example \"ordering_key\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_GCP_PUBSUB_MESSAGE_ORDERING_KEY = 'messaging.gcp_pubsub.message.ordering_key' as const;\n\n/**\n * Deprecated, use `messaging.consumer.group.name` instead.\n *\n * @example \"my-group\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `messaging.consumer.group.name`.\n */\nexport const ATTR_MESSAGING_KAFKA_CONSUMER_GROUP = 'messaging.kafka.consumer.group' as const;\n\n/**\n * Deprecated, use `messaging.destination.partition.id` instead.\n *\n * @example 2\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Record string representation of the partition id in `messaging.destination.partition.id` attribute.\n */\nexport const ATTR_MESSAGING_KAFKA_DESTINATION_PARTITION = 'messaging.kafka.destination.partition' as const;\n\n/**\n * Message keys in Kafka are used for grouping alike messages to ensure they're processed on the same partition. They differ from `messaging.message.id` in that they're not unique. If the key is `null`, the attribute **MUST NOT** be set.\n *\n * @example \"myKey\"\n *\n * @note If the key type is not string, it's string representation has to be supplied for the attribute. If the key has no unambiguous, canonical string form, don't include its value.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_KAFKA_MESSAGE_KEY = 'messaging.kafka.message.key' as const;\n\n/**\n * Deprecated, use `messaging.kafka.offset` instead.\n *\n * @example 42\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `messaging.kafka.offset`.\n */\nexport const ATTR_MESSAGING_KAFKA_MESSAGE_OFFSET = 'messaging.kafka.message.offset' as const;\n\n/**\n * A boolean that is true if the message is a tombstone.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_KAFKA_MESSAGE_TOMBSTONE = 'messaging.kafka.message.tombstone' as const;\n\n/**\n * The offset of a record in the corresponding Kafka partition.\n *\n * @example 42\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_KAFKA_OFFSET = 'messaging.kafka.offset' as const;\n\n/**\n * The size of the message body in bytes.\n *\n * @example 1439\n *\n * @note This can refer to both the compressed or uncompressed body size. If both sizes are known, the uncompressed\n * body size should be used.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_MESSAGE_BODY_SIZE = 'messaging.message.body.size' as const;\n\n/**\n * The conversation ID identifying the conversation to which the message belongs, represented as a string. Sometimes called \"Correlation ID\".\n *\n * @example \"MyConversationId\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_MESSAGE_CONVERSATION_ID = 'messaging.message.conversation_id' as const;\n\n/**\n * The size of the message body and metadata in bytes.\n *\n * @example 2738\n *\n * @note This can refer to both the compressed or uncompressed size. If both sizes are known, the uncompressed\n * size should be used.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_MESSAGE_ENVELOPE_SIZE = 'messaging.message.envelope.size' as const;\n\n/**\n * A value used by the messaging system as an identifier for the message, represented as a string.\n *\n * @example \"452a7c7c7c7048c2f887f61572b18fc2\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_MESSAGE_ID = 'messaging.message.id' as const;\n\n/**\n * Deprecated, use `messaging.operation.type` instead.\n *\n * @example publish\n * @example create\n * @example process\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `messaging.operation.type`.\n */\nexport const ATTR_MESSAGING_OPERATION = 'messaging.operation' as const;\n\n/**\n * The system-specific name of the messaging operation.\n *\n * @example ack\n * @example nack\n * @example send\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_OPERATION_NAME = 'messaging.operation.name' as const;\n\n/**\n * A string identifying the type of the messaging operation.\n *\n * @note If a custom value is used, it **MUST** be of low cardinality.\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_OPERATION_TYPE = 'messaging.operation.type' as const;\n\n/**\n * Enum value \"create\" for attribute {@link ATTR_MESSAGING_OPERATION_TYPE}.\n *\n * A message is created. \"Create\" spans always refer to a single message and are used to provide a unique creation context for messages in batch sending scenarios.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_OPERATION_TYPE_VALUE_CREATE = \"create\" as const;\n\n/**\n * Enum value \"deliver\" for attribute {@link ATTR_MESSAGING_OPERATION_TYPE}.\n *\n * Deprecated. Use `process` instead.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `process`.\n */\nexport const MESSAGING_OPERATION_TYPE_VALUE_DELIVER = \"deliver\" as const;\n\n/**\n * Enum value \"process\" for attribute {@link ATTR_MESSAGING_OPERATION_TYPE}.\n *\n * One or more messages are processed by a consumer.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_OPERATION_TYPE_VALUE_PROCESS = \"process\" as const;\n\n/**\n * Enum value \"publish\" for attribute {@link ATTR_MESSAGING_OPERATION_TYPE}.\n *\n * Deprecated. Use `send` instead.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `send`.\n */\nexport const MESSAGING_OPERATION_TYPE_VALUE_PUBLISH = \"publish\" as const;\n\n/**\n * Enum value \"receive\" for attribute {@link ATTR_MESSAGING_OPERATION_TYPE}.\n *\n * One or more messages are requested by a consumer. This operation refers to pull-based scenarios, where consumers explicitly call methods of messaging SDKs to receive messages.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_OPERATION_TYPE_VALUE_RECEIVE = \"receive\" as const;\n\n/**\n * Enum value \"send\" for attribute {@link ATTR_MESSAGING_OPERATION_TYPE}.\n *\n * One or more messages are provided for sending to an intermediary. If a single message is sent, the context of the \"Send\" span can be used as the creation context and no \"Create\" span needs to be created.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_OPERATION_TYPE_VALUE_SEND = \"send\" as const;\n\n/**\n * Enum value \"settle\" for attribute {@link ATTR_MESSAGING_OPERATION_TYPE}.\n *\n * One or more messages are settled.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_OPERATION_TYPE_VALUE_SETTLE = \"settle\" as const;\n\n/**\n * RabbitMQ message routing key.\n *\n * @example \"myKey\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_RABBITMQ_DESTINATION_ROUTING_KEY = 'messaging.rabbitmq.destination.routing_key' as const;\n\n/**\n * RabbitMQ message delivery tag\n *\n * @example 123\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_RABBITMQ_MESSAGE_DELIVERY_TAG = 'messaging.rabbitmq.message.delivery_tag' as const;\n\n/**\n * Deprecated, use `messaging.consumer.group.name` instead.\n *\n * @example \"myConsumerGroup\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `messaging.consumer.group.name` on the consumer spans. No replacement for producer spans.\n */\nexport const ATTR_MESSAGING_ROCKETMQ_CLIENT_GROUP = 'messaging.rocketmq.client_group' as const;\n\n/**\n * Model of message consumption. This only applies to consumer spans.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_ROCKETMQ_CONSUMPTION_MODEL = 'messaging.rocketmq.consumption_model' as const;\n\n/**\n * Enum value \"broadcasting\" for attribute {@link ATTR_MESSAGING_ROCKETMQ_CONSUMPTION_MODEL}.\n *\n * Broadcasting consumption model\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_ROCKETMQ_CONSUMPTION_MODEL_VALUE_BROADCASTING = \"broadcasting\" as const;\n\n/**\n * Enum value \"clustering\" for attribute {@link ATTR_MESSAGING_ROCKETMQ_CONSUMPTION_MODEL}.\n *\n * Clustering consumption model\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_ROCKETMQ_CONSUMPTION_MODEL_VALUE_CLUSTERING = \"clustering\" as const;\n\n/**\n * The delay time level for delay message, which determines the message delay time.\n *\n * @example 3\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_ROCKETMQ_MESSAGE_DELAY_TIME_LEVEL = 'messaging.rocketmq.message.delay_time_level' as const;\n\n/**\n * The timestamp in milliseconds that the delay message is expected to be delivered to consumer.\n *\n * @example 1665987217045\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_ROCKETMQ_MESSAGE_DELIVERY_TIMESTAMP = 'messaging.rocketmq.message.delivery_timestamp' as const;\n\n/**\n * It is essential for FIFO message. Messages that belong to the same message group are always processed one by one within the same consumer group.\n *\n * @example \"myMessageGroup\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_ROCKETMQ_MESSAGE_GROUP = 'messaging.rocketmq.message.group' as const;\n\n/**\n * Key(s) of message, another way to mark message besides message id.\n *\n * @example [\"keyA\", \"keyB\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_ROCKETMQ_MESSAGE_KEYS = 'messaging.rocketmq.message.keys' as const;\n\n/**\n * The secondary classifier of message besides topic.\n *\n * @example \"tagA\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_ROCKETMQ_MESSAGE_TAG = 'messaging.rocketmq.message.tag' as const;\n\n/**\n * Type of message.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_ROCKETMQ_MESSAGE_TYPE = 'messaging.rocketmq.message.type' as const;\n\n/**\n * Enum value \"delay\" for attribute {@link ATTR_MESSAGING_ROCKETMQ_MESSAGE_TYPE}.\n *\n * Delay message\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_ROCKETMQ_MESSAGE_TYPE_VALUE_DELAY = \"delay\" as const;\n\n/**\n * Enum value \"fifo\" for attribute {@link ATTR_MESSAGING_ROCKETMQ_MESSAGE_TYPE}.\n *\n * FIFO message\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_ROCKETMQ_MESSAGE_TYPE_VALUE_FIFO = \"fifo\" as const;\n\n/**\n * Enum value \"normal\" for attribute {@link ATTR_MESSAGING_ROCKETMQ_MESSAGE_TYPE}.\n *\n * Normal message\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_ROCKETMQ_MESSAGE_TYPE_VALUE_NORMAL = \"normal\" as const;\n\n/**\n * Enum value \"transaction\" for attribute {@link ATTR_MESSAGING_ROCKETMQ_MESSAGE_TYPE}.\n *\n * Transaction message\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_ROCKETMQ_MESSAGE_TYPE_VALUE_TRANSACTION = \"transaction\" as const;\n\n/**\n * Namespace of RocketMQ resources, resources in different namespaces are individual.\n *\n * @example \"myNamespace\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_ROCKETMQ_NAMESPACE = 'messaging.rocketmq.namespace' as const;\n\n/**\n * Deprecated, use `messaging.destination.subscription.name` instead.\n *\n * @example \"subscription-a\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `messaging.destination.subscription.name`.\n */\nexport const ATTR_MESSAGING_SERVICEBUS_DESTINATION_SUBSCRIPTION_NAME = 'messaging.servicebus.destination.subscription_name' as const;\n\n/**\n * Describes the [settlement type](https://learn.microsoft.com/azure/service-bus-messaging/message-transfers-locks-settlement#peeklock).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_SERVICEBUS_DISPOSITION_STATUS = 'messaging.servicebus.disposition_status' as const;\n\n/**\n * Enum value \"abandon\" for attribute {@link ATTR_MESSAGING_SERVICEBUS_DISPOSITION_STATUS}.\n *\n * Message is abandoned\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SERVICEBUS_DISPOSITION_STATUS_VALUE_ABANDON = \"abandon\" as const;\n\n/**\n * Enum value \"complete\" for attribute {@link ATTR_MESSAGING_SERVICEBUS_DISPOSITION_STATUS}.\n *\n * Message is completed\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SERVICEBUS_DISPOSITION_STATUS_VALUE_COMPLETE = \"complete\" as const;\n\n/**\n * Enum value \"dead_letter\" for attribute {@link ATTR_MESSAGING_SERVICEBUS_DISPOSITION_STATUS}.\n *\n * Message is sent to dead letter queue\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SERVICEBUS_DISPOSITION_STATUS_VALUE_DEAD_LETTER = \"dead_letter\" as const;\n\n/**\n * Enum value \"defer\" for attribute {@link ATTR_MESSAGING_SERVICEBUS_DISPOSITION_STATUS}.\n *\n * Message is deferred\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SERVICEBUS_DISPOSITION_STATUS_VALUE_DEFER = \"defer\" as const;\n\n/**\n * Number of deliveries that have been attempted for this message.\n *\n * @example 2\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_SERVICEBUS_MESSAGE_DELIVERY_COUNT = 'messaging.servicebus.message.delivery_count' as const;\n\n/**\n * The UTC epoch seconds at which the message has been accepted and stored in the entity.\n *\n * @example 1701393730\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_SERVICEBUS_MESSAGE_ENQUEUED_TIME = 'messaging.servicebus.message.enqueued_time' as const;\n\n/**\n * The messaging system as identified by the client instrumentation.\n *\n * @note The actual messaging system may differ from the one known by the client. For example, when using Kafka client libraries to communicate with Azure Event Hubs, the `messaging.system` is set to `kafka` based on the instrumentation's best knowledge.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_MESSAGING_SYSTEM = 'messaging.system' as const;\n\n/**\n * Enum value \"activemq\" for attribute {@link ATTR_MESSAGING_SYSTEM}.\n *\n * Apache ActiveMQ\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SYSTEM_VALUE_ACTIVEMQ = \"activemq\" as const;\n\n/**\n * Enum value \"aws.sns\" for attribute {@link ATTR_MESSAGING_SYSTEM}.\n *\n * Amazon Simple Notification Service (SNS)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SYSTEM_VALUE_AWS_SNS = \"aws.sns\" as const;\n\n/**\n * Enum value \"aws_sqs\" for attribute {@link ATTR_MESSAGING_SYSTEM}.\n *\n * Amazon Simple Queue Service (SQS)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SYSTEM_VALUE_AWS_SQS = \"aws_sqs\" as const;\n\n/**\n * Enum value \"eventgrid\" for attribute {@link ATTR_MESSAGING_SYSTEM}.\n *\n * Azure Event Grid\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SYSTEM_VALUE_EVENTGRID = \"eventgrid\" as const;\n\n/**\n * Enum value \"eventhubs\" for attribute {@link ATTR_MESSAGING_SYSTEM}.\n *\n * Azure Event Hubs\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SYSTEM_VALUE_EVENTHUBS = \"eventhubs\" as const;\n\n/**\n * Enum value \"gcp_pubsub\" for attribute {@link ATTR_MESSAGING_SYSTEM}.\n *\n * Google Cloud Pub/Sub\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SYSTEM_VALUE_GCP_PUBSUB = \"gcp_pubsub\" as const;\n\n/**\n * Enum value \"jms\" for attribute {@link ATTR_MESSAGING_SYSTEM}.\n *\n * Java Message Service\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SYSTEM_VALUE_JMS = \"jms\" as const;\n\n/**\n * Enum value \"kafka\" for attribute {@link ATTR_MESSAGING_SYSTEM}.\n *\n * Apache Kafka\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SYSTEM_VALUE_KAFKA = \"kafka\" as const;\n\n/**\n * Enum value \"pulsar\" for attribute {@link ATTR_MESSAGING_SYSTEM}.\n *\n * Apache Pulsar\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SYSTEM_VALUE_PULSAR = \"pulsar\" as const;\n\n/**\n * Enum value \"rabbitmq\" for attribute {@link ATTR_MESSAGING_SYSTEM}.\n *\n * RabbitMQ\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SYSTEM_VALUE_RABBITMQ = \"rabbitmq\" as const;\n\n/**\n * Enum value \"rocketmq\" for attribute {@link ATTR_MESSAGING_SYSTEM}.\n *\n * Apache RocketMQ\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SYSTEM_VALUE_ROCKETMQ = \"rocketmq\" as const;\n\n/**\n * Enum value \"servicebus\" for attribute {@link ATTR_MESSAGING_SYSTEM}.\n *\n * Azure Service Bus\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const MESSAGING_SYSTEM_VALUE_SERVICEBUS = \"servicebus\" as const;\n\n/**\n * Deprecated, use `network.local.address`.\n *\n * @example \"192.168.0.1\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `network.local.address`.\n */\nexport const ATTR_NET_HOST_IP = 'net.host.ip' as const;\n\n/**\n * Deprecated, use `server.address`.\n *\n * @example example.com\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `server.address`.\n */\nexport const ATTR_NET_HOST_NAME = 'net.host.name' as const;\n\n/**\n * Deprecated, use `server.port`.\n *\n * @example 8080\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `server.port`.\n */\nexport const ATTR_NET_HOST_PORT = 'net.host.port' as const;\n\n/**\n * Deprecated, use `network.peer.address`.\n *\n * @example \"127.0.0.1\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `network.peer.address`.\n */\nexport const ATTR_NET_PEER_IP = 'net.peer.ip' as const;\n\n/**\n * Deprecated, use `server.address` on client spans and `client.address` on server spans.\n *\n * @example example.com\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `server.address` on client spans and `client.address` on server spans.\n */\nexport const ATTR_NET_PEER_NAME = 'net.peer.name' as const;\n\n/**\n * Deprecated, use `server.port` on client spans and `client.port` on server spans.\n *\n * @example 8080\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `server.port` on client spans and `client.port` on server spans.\n */\nexport const ATTR_NET_PEER_PORT = 'net.peer.port' as const;\n\n/**\n * Deprecated, use `network.protocol.name`.\n *\n * @example amqp\n * @example http\n * @example mqtt\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `network.protocol.name`.\n */\nexport const ATTR_NET_PROTOCOL_NAME = 'net.protocol.name' as const;\n\n/**\n * Deprecated, use `network.protocol.version`.\n *\n * @example \"3.1.1\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `network.protocol.version`.\n */\nexport const ATTR_NET_PROTOCOL_VERSION = 'net.protocol.version' as const;\n\n/**\n * Deprecated, use `network.transport` and `network.type`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Split to `network.transport` and `network.type`.\n */\nexport const ATTR_NET_SOCK_FAMILY = 'net.sock.family' as const;\n\n/**\n * Enum value \"inet\" for attribute {@link ATTR_NET_SOCK_FAMILY}.\n *\n * IPv4 address\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NET_SOCK_FAMILY_VALUE_INET = \"inet\" as const;\n\n/**\n * Enum value \"inet6\" for attribute {@link ATTR_NET_SOCK_FAMILY}.\n *\n * IPv6 address\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NET_SOCK_FAMILY_VALUE_INET6 = \"inet6\" as const;\n\n/**\n * Enum value \"unix\" for attribute {@link ATTR_NET_SOCK_FAMILY}.\n *\n * Unix domain socket path\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NET_SOCK_FAMILY_VALUE_UNIX = \"unix\" as const;\n\n/**\n * Deprecated, use `network.local.address`.\n *\n * @example /var/my.sock\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `network.local.address`.\n */\nexport const ATTR_NET_SOCK_HOST_ADDR = 'net.sock.host.addr' as const;\n\n/**\n * Deprecated, use `network.local.port`.\n *\n * @example 8080\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `network.local.port`.\n */\nexport const ATTR_NET_SOCK_HOST_PORT = 'net.sock.host.port' as const;\n\n/**\n * Deprecated, use `network.peer.address`.\n *\n * @example 192.168.0.1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `network.peer.address`.\n */\nexport const ATTR_NET_SOCK_PEER_ADDR = 'net.sock.peer.addr' as const;\n\n/**\n * Deprecated, no replacement at this time.\n *\n * @example /var/my.sock\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Removed. No replacement at this time.\n */\nexport const ATTR_NET_SOCK_PEER_NAME = 'net.sock.peer.name' as const;\n\n/**\n * Deprecated, use `network.peer.port`.\n *\n * @example 65531\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `network.peer.port`.\n */\nexport const ATTR_NET_SOCK_PEER_PORT = 'net.sock.peer.port' as const;\n\n/**\n * Deprecated, use `network.transport`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `network.transport`.\n */\nexport const ATTR_NET_TRANSPORT = 'net.transport' as const;\n\n/**\n * Enum value \"inproc\" for attribute {@link ATTR_NET_TRANSPORT}.\n *\n * In-process communication.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NET_TRANSPORT_VALUE_INPROC = \"inproc\" as const;\n\n/**\n * Enum value \"ip_tcp\" for attribute {@link ATTR_NET_TRANSPORT}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NET_TRANSPORT_VALUE_IP_TCP = \"ip_tcp\" as const;\n\n/**\n * Enum value \"ip_udp\" for attribute {@link ATTR_NET_TRANSPORT}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NET_TRANSPORT_VALUE_IP_UDP = \"ip_udp\" as const;\n\n/**\n * Enum value \"other\" for attribute {@link ATTR_NET_TRANSPORT}.\n *\n * Something else (non IP-based).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NET_TRANSPORT_VALUE_OTHER = \"other\" as const;\n\n/**\n * Enum value \"pipe\" for attribute {@link ATTR_NET_TRANSPORT}.\n *\n * Named or anonymous pipe.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NET_TRANSPORT_VALUE_PIPE = \"pipe\" as const;\n\n/**\n * The ISO 3166-1 alpha-2 2-character country code associated with the mobile carrier network.\n *\n * @example \"DE\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_NETWORK_CARRIER_ICC = 'network.carrier.icc' as const;\n\n/**\n * The mobile carrier country code.\n *\n * @example \"310\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_NETWORK_CARRIER_MCC = 'network.carrier.mcc' as const;\n\n/**\n * The mobile carrier network code.\n *\n * @example \"001\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_NETWORK_CARRIER_MNC = 'network.carrier.mnc' as const;\n\n/**\n * The name of the mobile carrier.\n *\n * @example \"sprint\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_NETWORK_CARRIER_NAME = 'network.carrier.name' as const;\n\n/**\n * The state of network connection\n *\n * @example close_wait\n *\n * @note Connection states are defined as part of the [rfc9293](https://datatracker.ietf.org/doc/html/rfc9293#section-3.3.2)\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_NETWORK_CONNECTION_STATE = 'network.connection.state' as const;\n\n/**\n * Enum value \"close_wait\" for attribute {@link ATTR_NETWORK_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_STATE_VALUE_CLOSE_WAIT = \"close_wait\" as const;\n\n/**\n * Enum value \"closed\" for attribute {@link ATTR_NETWORK_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_STATE_VALUE_CLOSED = \"closed\" as const;\n\n/**\n * Enum value \"closing\" for attribute {@link ATTR_NETWORK_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_STATE_VALUE_CLOSING = \"closing\" as const;\n\n/**\n * Enum value \"established\" for attribute {@link ATTR_NETWORK_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_STATE_VALUE_ESTABLISHED = \"established\" as const;\n\n/**\n * Enum value \"fin_wait_1\" for attribute {@link ATTR_NETWORK_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_STATE_VALUE_FIN_WAIT_1 = \"fin_wait_1\" as const;\n\n/**\n * Enum value \"fin_wait_2\" for attribute {@link ATTR_NETWORK_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_STATE_VALUE_FIN_WAIT_2 = \"fin_wait_2\" as const;\n\n/**\n * Enum value \"last_ack\" for attribute {@link ATTR_NETWORK_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_STATE_VALUE_LAST_ACK = \"last_ack\" as const;\n\n/**\n * Enum value \"listen\" for attribute {@link ATTR_NETWORK_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_STATE_VALUE_LISTEN = \"listen\" as const;\n\n/**\n * Enum value \"syn_received\" for attribute {@link ATTR_NETWORK_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_STATE_VALUE_SYN_RECEIVED = \"syn_received\" as const;\n\n/**\n * Enum value \"syn_sent\" for attribute {@link ATTR_NETWORK_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_STATE_VALUE_SYN_SENT = \"syn_sent\" as const;\n\n/**\n * Enum value \"time_wait\" for attribute {@link ATTR_NETWORK_CONNECTION_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_STATE_VALUE_TIME_WAIT = \"time_wait\" as const;\n\n/**\n * This describes more details regarding the connection.type. It may be the type of cell technology connection, but it could be used for describing details about a wifi connection.\n *\n * @example \"LTE\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_NETWORK_CONNECTION_SUBTYPE = 'network.connection.subtype' as const;\n\n/**\n * Enum value \"cdma\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * CDMA\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_CDMA = \"cdma\" as const;\n\n/**\n * Enum value \"cdma2000_1xrtt\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * CDMA2000 1XRTT\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_CDMA2000_1XRTT = \"cdma2000_1xrtt\" as const;\n\n/**\n * Enum value \"edge\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * EDGE\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_EDGE = \"edge\" as const;\n\n/**\n * Enum value \"ehrpd\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * EHRPD\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_EHRPD = \"ehrpd\" as const;\n\n/**\n * Enum value \"evdo_0\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * EVDO Rel. 0\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_EVDO_0 = \"evdo_0\" as const;\n\n/**\n * Enum value \"evdo_a\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * EVDO Rev. A\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_EVDO_A = \"evdo_a\" as const;\n\n/**\n * Enum value \"evdo_b\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * EVDO Rev. B\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_EVDO_B = \"evdo_b\" as const;\n\n/**\n * Enum value \"gprs\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * GPRS\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_GPRS = \"gprs\" as const;\n\n/**\n * Enum value \"gsm\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * GSM\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_GSM = \"gsm\" as const;\n\n/**\n * Enum value \"hsdpa\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * HSDPA\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_HSDPA = \"hsdpa\" as const;\n\n/**\n * Enum value \"hspa\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * HSPA\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_HSPA = \"hspa\" as const;\n\n/**\n * Enum value \"hspap\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * HSPAP\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_HSPAP = \"hspap\" as const;\n\n/**\n * Enum value \"hsupa\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * HSUPA\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_HSUPA = \"hsupa\" as const;\n\n/**\n * Enum value \"iden\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * IDEN\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_IDEN = \"iden\" as const;\n\n/**\n * Enum value \"iwlan\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * IWLAN\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_IWLAN = \"iwlan\" as const;\n\n/**\n * Enum value \"lte\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * LTE\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_LTE = \"lte\" as const;\n\n/**\n * Enum value \"lte_ca\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * LTE CA\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_LTE_CA = \"lte_ca\" as const;\n\n/**\n * Enum value \"nr\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * 5G NR (New Radio)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_NR = \"nr\" as const;\n\n/**\n * Enum value \"nrnsa\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * 5G NRNSA (New Radio Non-Standalone)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_NRNSA = \"nrnsa\" as const;\n\n/**\n * Enum value \"td_scdma\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * TD-SCDMA\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_TD_SCDMA = \"td_scdma\" as const;\n\n/**\n * Enum value \"umts\" for attribute {@link ATTR_NETWORK_CONNECTION_SUBTYPE}.\n *\n * UMTS\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_SUBTYPE_VALUE_UMTS = \"umts\" as const;\n\n/**\n * The internet connection type.\n *\n * @example \"wifi\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_NETWORK_CONNECTION_TYPE = 'network.connection.type' as const;\n\n/**\n * Enum value \"cell\" for attribute {@link ATTR_NETWORK_CONNECTION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_TYPE_VALUE_CELL = \"cell\" as const;\n\n/**\n * Enum value \"unavailable\" for attribute {@link ATTR_NETWORK_CONNECTION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_TYPE_VALUE_UNAVAILABLE = \"unavailable\" as const;\n\n/**\n * Enum value \"unknown\" for attribute {@link ATTR_NETWORK_CONNECTION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_TYPE_VALUE_UNKNOWN = \"unknown\" as const;\n\n/**\n * Enum value \"wifi\" for attribute {@link ATTR_NETWORK_CONNECTION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_TYPE_VALUE_WIFI = \"wifi\" as const;\n\n/**\n * Enum value \"wired\" for attribute {@link ATTR_NETWORK_CONNECTION_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_CONNECTION_TYPE_VALUE_WIRED = \"wired\" as const;\n\n/**\n * The network interface name.\n *\n * @example lo\n * @example eth0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_NETWORK_INTERFACE_NAME = 'network.interface.name' as const;\n\n/**\n * The network IO operation direction.\n *\n * @example transmit\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_NETWORK_IO_DIRECTION = 'network.io.direction' as const;\n\n/**\n * Enum value \"receive\" for attribute {@link ATTR_NETWORK_IO_DIRECTION}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_IO_DIRECTION_VALUE_RECEIVE = \"receive\" as const;\n\n/**\n * Enum value \"transmit\" for attribute {@link ATTR_NETWORK_IO_DIRECTION}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NETWORK_IO_DIRECTION_VALUE_TRANSMIT = \"transmit\" as const;\n\n/**\n * NFSv4+ operation name.\n *\n * @example OPEN\n * @example READ\n * @example GETATTR\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_NFS_OPERATION_NAME = 'nfs.operation.name' as const;\n\n/**\n * Linux: one of \"hit\" (NFSD_STATS_RC_HITS), \"miss\" (NFSD_STATS_RC_MISSES), or \"nocache\" (NFSD_STATS_RC_NOCACHE -- uncacheable)\n *\n * @example \"hit\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_NFS_SERVER_REPCACHE_STATUS = 'nfs.server.repcache.status' as const;\n\n/**\n * The state of event loop time.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_NODEJS_EVENTLOOP_STATE = 'nodejs.eventloop.state' as const;\n\n/**\n * Enum value \"active\" for attribute {@link ATTR_NODEJS_EVENTLOOP_STATE}.\n *\n * Active time.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NODEJS_EVENTLOOP_STATE_VALUE_ACTIVE = \"active\" as const;\n\n/**\n * Enum value \"idle\" for attribute {@link ATTR_NODEJS_EVENTLOOP_STATE}.\n *\n * Idle time.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const NODEJS_EVENTLOOP_STATE_VALUE_IDLE = \"idle\" as const;\n\n/**\n * The digest of the OCI image manifest. For container images specifically is the digest by which the container image is known.\n *\n * @example sha256:e4ca62c0d62f3e886e684806dfe9d4e0cda60d54986898173c1083856cfda0f4\n *\n * @note Follows [OCI Image Manifest Specification](https://github.com/opencontainers/image-spec/blob/main/manifest.md), and specifically the [Digest property](https://github.com/opencontainers/image-spec/blob/main/descriptor.md#digests).\n * An example can be found in [Example Image Manifest](https://github.com/opencontainers/image-spec/blob/main/manifest.md#example-image-manifest).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OCI_MANIFEST_DIGEST = 'oci.manifest.digest' as const;\n\n/**\n * ONC/Sun RPC procedure name.\n *\n * @example OPEN\n * @example READ\n * @example GETATTR\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ONC_RPC_PROCEDURE_NAME = 'onc_rpc.procedure.name' as const;\n\n/**\n * ONC/Sun RPC procedure number.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ONC_RPC_PROCEDURE_NUMBER = 'onc_rpc.procedure.number' as const;\n\n/**\n * ONC/Sun RPC program name.\n *\n * @example portmapper\n * @example nfs\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ONC_RPC_PROGRAM_NAME = 'onc_rpc.program.name' as const;\n\n/**\n * ONC/Sun RPC program version.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ONC_RPC_VERSION = 'onc_rpc.version' as const;\n\n/**\n * The service tier requested. May be a specific tier, default, or auto.\n *\n * @example auto\n * @example default\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OPENAI_REQUEST_SERVICE_TIER = 'openai.request.service_tier' as const;\n\n/**\n * Enum value \"auto\" for attribute {@link ATTR_OPENAI_REQUEST_SERVICE_TIER}.\n *\n * The system will utilize scale tier credits until they are exhausted.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OPENAI_REQUEST_SERVICE_TIER_VALUE_AUTO = \"auto\" as const;\n\n/**\n * Enum value \"default\" for attribute {@link ATTR_OPENAI_REQUEST_SERVICE_TIER}.\n *\n * The system will utilize the default scale tier.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OPENAI_REQUEST_SERVICE_TIER_VALUE_DEFAULT = \"default\" as const;\n\n/**\n * The service tier used for the response.\n *\n * @example scale\n * @example default\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OPENAI_RESPONSE_SERVICE_TIER = 'openai.response.service_tier' as const;\n\n/**\n * A fingerprint to track any eventual change in the Generative AI environment.\n *\n * @example fp_44709d6fcb\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OPENAI_RESPONSE_SYSTEM_FINGERPRINT = 'openai.response.system_fingerprint' as const;\n\n/**\n * The name of the cluster quota.\n *\n * @example opentelemetry\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OPENSHIFT_CLUSTERQUOTA_NAME = 'openshift.clusterquota.name' as const;\n\n/**\n * The UID of the cluster quota.\n *\n * @example 275ecb36-5aa8-4c2a-9c47-d8bb681b9aff\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OPENSHIFT_CLUSTERQUOTA_UID = 'openshift.clusterquota.uid' as const;\n\n/**\n * Parent-child Reference type\n *\n * @note The causal relationship between a child Span and a parent Span.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OPENTRACING_REF_TYPE = 'opentracing.ref_type' as const;\n\n/**\n * Enum value \"child_of\" for attribute {@link ATTR_OPENTRACING_REF_TYPE}.\n *\n * The parent Span depends on the child Span in some capacity\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OPENTRACING_REF_TYPE_VALUE_CHILD_OF = \"child_of\" as const;\n\n/**\n * Enum value \"follows_from\" for attribute {@link ATTR_OPENTRACING_REF_TYPE}.\n *\n * The parent Span doesn't depend in any way on the result of the child Span\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OPENTRACING_REF_TYPE_VALUE_FOLLOWS_FROM = \"follows_from\" as const;\n\n/**\n * Unique identifier for a particular build or compilation of the operating system.\n *\n * @example TQ3C.230805.001.B2\n * @example 20E247\n * @example 22621\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OS_BUILD_ID = 'os.build_id' as const;\n\n/**\n * Human readable (not intended to be parsed) OS version information, like e.g. reported by `ver` or `lsb_release -a` commands.\n *\n * @example Microsoft Windows [Version 10.0.18363.778]\n * @example Ubuntu 18.04.1 LTS\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OS_DESCRIPTION = 'os.description' as const;\n\n/**\n * Human readable operating system name.\n *\n * @example iOS\n * @example Android\n * @example Ubuntu\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OS_NAME = 'os.name' as const;\n\n/**\n * The operating system type.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OS_TYPE = 'os.type' as const;\n\n/**\n * Enum value \"aix\" for attribute {@link ATTR_OS_TYPE}.\n *\n * AIX (Advanced Interactive eXecutive)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OS_TYPE_VALUE_AIX = \"aix\" as const;\n\n/**\n * Enum value \"darwin\" for attribute {@link ATTR_OS_TYPE}.\n *\n * Apple Darwin\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OS_TYPE_VALUE_DARWIN = \"darwin\" as const;\n\n/**\n * Enum value \"dragonflybsd\" for attribute {@link ATTR_OS_TYPE}.\n *\n * DragonFly BSD\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OS_TYPE_VALUE_DRAGONFLYBSD = \"dragonflybsd\" as const;\n\n/**\n * Enum value \"freebsd\" for attribute {@link ATTR_OS_TYPE}.\n *\n * FreeBSD\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OS_TYPE_VALUE_FREEBSD = \"freebsd\" as const;\n\n/**\n * Enum value \"hpux\" for attribute {@link ATTR_OS_TYPE}.\n *\n * HP-UX (Hewlett Packard Unix)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OS_TYPE_VALUE_HPUX = \"hpux\" as const;\n\n/**\n * Enum value \"linux\" for attribute {@link ATTR_OS_TYPE}.\n *\n * Linux\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OS_TYPE_VALUE_LINUX = \"linux\" as const;\n\n/**\n * Enum value \"netbsd\" for attribute {@link ATTR_OS_TYPE}.\n *\n * NetBSD\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OS_TYPE_VALUE_NETBSD = \"netbsd\" as const;\n\n/**\n * Enum value \"openbsd\" for attribute {@link ATTR_OS_TYPE}.\n *\n * OpenBSD\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OS_TYPE_VALUE_OPENBSD = \"openbsd\" as const;\n\n/**\n * Enum value \"solaris\" for attribute {@link ATTR_OS_TYPE}.\n *\n * SunOS, Oracle Solaris\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OS_TYPE_VALUE_SOLARIS = \"solaris\" as const;\n\n/**\n * Enum value \"windows\" for attribute {@link ATTR_OS_TYPE}.\n *\n * Microsoft Windows\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OS_TYPE_VALUE_WINDOWS = \"windows\" as const;\n\n/**\n * Enum value \"z_os\" for attribute {@link ATTR_OS_TYPE}.\n *\n * Deprecated. Use `zos` instead.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `zos`.\n */\nexport const OS_TYPE_VALUE_Z_OS = \"z_os\" as const;\n\n/**\n * Enum value \"zos\" for attribute {@link ATTR_OS_TYPE}.\n *\n * IBM z/OS\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OS_TYPE_VALUE_ZOS = \"zos\" as const;\n\n/**\n * The version string of the operating system as defined in [Version Attributes](/docs/resource/README.md#version-attributes).\n *\n * @example 14.2.1\n * @example 18.04.1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OS_VERSION = 'os.version' as const;\n\n/**\n * A name uniquely identifying the instance of the OpenTelemetry component within its containing SDK instance.\n *\n * @example otlp_grpc_span_exporter/0\n * @example custom-name\n *\n * @note Implementations **SHOULD** ensure a low cardinality for this attribute, even across application or SDK restarts.\n * E.g. implementations **MUST NOT** use UUIDs as values for this attribute.\n *\n * Implementations **MAY** achieve these goals by following a `<otel.component.type>/<instance-counter>` pattern, e.g. `batching_span_processor/0`.\n * Hereby `otel.component.type` refers to the corresponding attribute value of the component.\n *\n * The value of `instance-counter` **MAY** be automatically assigned by the component and uniqueness within the enclosing SDK instance **MUST** be guaranteed.\n * For example, `<instance-counter>` **MAY** be implemented by using a monotonically increasing counter (starting with `0`), which is incremented every time an\n * instance of the given component type is started.\n *\n * With this implementation, for example the first Batching Span Processor would have `batching_span_processor/0`\n * as `otel.component.name`, the second one `batching_span_processor/1` and so on.\n * These values will therefore be reused in the case of an application restart.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OTEL_COMPONENT_NAME = 'otel.component.name' as const;\n\n/**\n * A name identifying the type of the OpenTelemetry component.\n *\n * @example batching_span_processor\n * @example com.example.MySpanExporter\n *\n * @note If none of the standardized values apply, implementations **SHOULD** use the language-defined name of the type.\n * E.g. for Java the fully qualified classname **SHOULD** be used in this case.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OTEL_COMPONENT_TYPE = 'otel.component.type' as const;\n\n/**\n * Enum value \"batching_log_processor\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * The builtin SDK batching log record processor\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_BATCHING_LOG_PROCESSOR = \"batching_log_processor\" as const;\n\n/**\n * Enum value \"batching_span_processor\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * The builtin SDK batching span processor\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_BATCHING_SPAN_PROCESSOR = \"batching_span_processor\" as const;\n\n/**\n * Enum value \"otlp_grpc_log_exporter\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * OTLP log record exporter over gRPC with protobuf serialization\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_OTLP_GRPC_LOG_EXPORTER = \"otlp_grpc_log_exporter\" as const;\n\n/**\n * Enum value \"otlp_grpc_metric_exporter\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * OTLP metric exporter over gRPC with protobuf serialization\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_OTLP_GRPC_METRIC_EXPORTER = \"otlp_grpc_metric_exporter\" as const;\n\n/**\n * Enum value \"otlp_grpc_span_exporter\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * OTLP span exporter over gRPC with protobuf serialization\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_OTLP_GRPC_SPAN_EXPORTER = \"otlp_grpc_span_exporter\" as const;\n\n/**\n * Enum value \"otlp_http_json_log_exporter\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * OTLP log record exporter over HTTP with JSON serialization\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_OTLP_HTTP_JSON_LOG_EXPORTER = \"otlp_http_json_log_exporter\" as const;\n\n/**\n * Enum value \"otlp_http_json_metric_exporter\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * OTLP metric exporter over HTTP with JSON serialization\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_OTLP_HTTP_JSON_METRIC_EXPORTER = \"otlp_http_json_metric_exporter\" as const;\n\n/**\n * Enum value \"otlp_http_json_span_exporter\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * OTLP span exporter over HTTP with JSON serialization\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_OTLP_HTTP_JSON_SPAN_EXPORTER = \"otlp_http_json_span_exporter\" as const;\n\n/**\n * Enum value \"otlp_http_log_exporter\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * OTLP log record exporter over HTTP with protobuf serialization\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_OTLP_HTTP_LOG_EXPORTER = \"otlp_http_log_exporter\" as const;\n\n/**\n * Enum value \"otlp_http_metric_exporter\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * OTLP metric exporter over HTTP with protobuf serialization\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_OTLP_HTTP_METRIC_EXPORTER = \"otlp_http_metric_exporter\" as const;\n\n/**\n * Enum value \"otlp_http_span_exporter\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * OTLP span exporter over HTTP with protobuf serialization\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_OTLP_HTTP_SPAN_EXPORTER = \"otlp_http_span_exporter\" as const;\n\n/**\n * Enum value \"periodic_metric_reader\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * The builtin SDK periodically exporting metric reader\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_PERIODIC_METRIC_READER = \"periodic_metric_reader\" as const;\n\n/**\n * Enum value \"prometheus_http_text_metric_exporter\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * Prometheus metric exporter over HTTP with the default text-based format\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_PROMETHEUS_HTTP_TEXT_METRIC_EXPORTER = \"prometheus_http_text_metric_exporter\" as const;\n\n/**\n * Enum value \"simple_log_processor\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * The builtin SDK simple log record processor\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_SIMPLE_LOG_PROCESSOR = \"simple_log_processor\" as const;\n\n/**\n * Enum value \"simple_span_processor\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * The builtin SDK simple span processor\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_SIMPLE_SPAN_PROCESSOR = \"simple_span_processor\" as const;\n\n/**\n * Enum value \"zipkin_http_span_exporter\" for attribute {@link ATTR_OTEL_COMPONENT_TYPE}.\n *\n * Zipkin span exporter over HTTP\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_COMPONENT_TYPE_VALUE_ZIPKIN_HTTP_SPAN_EXPORTER = \"zipkin_http_span_exporter\" as const;\n\n/**\n * Identifies the class / type of event.\n *\n * @example browser.mouse.click\n * @example device.app.lifecycle\n *\n * @note This attribute **SHOULD** be used by non-OTLP exporters when destination does not support `EventName` or equivalent field. This attribute **MAY** be used by applications using existing logging libraries so that it can be used to set the `EventName` field by Collector or SDK components.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OTEL_EVENT_NAME = 'otel.event.name' as const;\n\n/**\n * Deprecated. Use the `otel.scope.name` attribute\n *\n * @example io.opentelemetry.contrib.mongodb\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `otel.scope.name`.\n */\nexport const ATTR_OTEL_LIBRARY_NAME = 'otel.library.name' as const;\n\n/**\n * Deprecated. Use the `otel.scope.version` attribute.\n *\n * @example 1.0.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `otel.scope.version`.\n */\nexport const ATTR_OTEL_LIBRARY_VERSION = 'otel.library.version' as const;\n\n/**\n * The schema URL of the instrumentation scope.\n *\n * @example https://opentelemetry.io/schemas/1.31.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OTEL_SCOPE_SCHEMA_URL = 'otel.scope.schema_url' as const;\n\n/**\n * Determines whether the span has a parent span, and if so, [whether it is a remote parent](https://opentelemetry.io/docs/specs/otel/trace/api/#isremote)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OTEL_SPAN_PARENT_ORIGIN = 'otel.span.parent.origin' as const;\n\n/**\n * Enum value \"local\" for attribute {@link ATTR_OTEL_SPAN_PARENT_ORIGIN}.\n *\n * The span has a parent and the parent's span context [isRemote()](https://opentelemetry.io/docs/specs/otel/trace/api/#isremote) is false\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_SPAN_PARENT_ORIGIN_VALUE_LOCAL = \"local\" as const;\n\n/**\n * Enum value \"none\" for attribute {@link ATTR_OTEL_SPAN_PARENT_ORIGIN}.\n *\n * The span does not have a parent, it is a root span\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_SPAN_PARENT_ORIGIN_VALUE_NONE = \"none\" as const;\n\n/**\n * Enum value \"remote\" for attribute {@link ATTR_OTEL_SPAN_PARENT_ORIGIN}.\n *\n * The span has a parent and the parent's span context [isRemote()](https://opentelemetry.io/docs/specs/otel/trace/api/#isremote) is true\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_SPAN_PARENT_ORIGIN_VALUE_REMOTE = \"remote\" as const;\n\n/**\n * The result value of the sampler for this span\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_OTEL_SPAN_SAMPLING_RESULT = 'otel.span.sampling_result' as const;\n\n/**\n * Enum value \"DROP\" for attribute {@link ATTR_OTEL_SPAN_SAMPLING_RESULT}.\n *\n * The span is not sampled and not recording\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_SPAN_SAMPLING_RESULT_VALUE_DROP = \"DROP\" as const;\n\n/**\n * Enum value \"RECORD_AND_SAMPLE\" for attribute {@link ATTR_OTEL_SPAN_SAMPLING_RESULT}.\n *\n * The span is sampled and recording\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_SPAN_SAMPLING_RESULT_VALUE_RECORD_AND_SAMPLE = \"RECORD_AND_SAMPLE\" as const;\n\n/**\n * Enum value \"RECORD_ONLY\" for attribute {@link ATTR_OTEL_SPAN_SAMPLING_RESULT}.\n *\n * The span is not sampled, but recording\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const OTEL_SPAN_SAMPLING_RESULT_VALUE_RECORD_ONLY = \"RECORD_ONLY\" as const;\n\n/**\n * The [`service.name`](/docs/resource/README.md#service) of the remote service. **SHOULD** be equal to the actual `service.name` resource attribute of the remote service if any.\n *\n * @example \"AuthTokenCache\"\n *\n * @note Examples of `peer.service` that users may specify:\n *\n * - A Redis cache of auth tokens as `peer.service=\"AuthTokenCache\"`.\n * - A gRPC service `rpc.service=\"io.opentelemetry.AuthService\"` may be hosted in both a gateway, `peer.service=\"ExternalApiService\"` and a backend, `peer.service=\"AuthService\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `service.peer.name`.\n */\nexport const ATTR_PEER_SERVICE = 'peer.service' as const;\n\n/**\n * Deprecated, use `db.client.connection.pool.name` instead.\n *\n * @example myDataSource\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.client.connection.pool.name`.\n */\nexport const ATTR_POOL_NAME = 'pool.name' as const;\n\n/**\n * Provides an indication that multiple symbols map to this location's address, for example due to identical code folding by the linker. In that case the line information represents one of the multiple symbols. This field must be recomputed when the symbolization state of the profile changes.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PPROF_LOCATION_IS_FOLDED = 'pprof.location.is_folded' as const;\n\n/**\n * Indicates that there are filenames related to this mapping.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PPROF_MAPPING_HAS_FILENAMES = 'pprof.mapping.has_filenames' as const;\n\n/**\n * Indicates that there are functions related to this mapping.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PPROF_MAPPING_HAS_FUNCTIONS = 'pprof.mapping.has_functions' as const;\n\n/**\n * Indicates that there are inline frames related to this mapping.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PPROF_MAPPING_HAS_INLINE_FRAMES = 'pprof.mapping.has_inline_frames' as const;\n\n/**\n * Indicates that there are line numbers related to this mapping.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PPROF_MAPPING_HAS_LINE_NUMBERS = 'pprof.mapping.has_line_numbers' as const;\n\n/**\n * Free-form text associated with the profile. This field should not be used to store any machine-readable information, it is only for human-friendly content.\n *\n * @example [\"hello world\", \"bazinga\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PPROF_PROFILE_COMMENT = 'pprof.profile.comment' as const;\n\n/**\n * Documentation link for this profile type.\n *\n * @example http://pprof.example.com/cpu-profile.html\n *\n * @note The URL must be absolute and may be missing if the profile was generated by code that did not supply a link\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PPROF_PROFILE_DOC_URL = 'pprof.profile.doc_url' as const;\n\n/**\n * Frames with Function.function_name fully matching the regexp will be dropped from the samples, along with their successors.\n *\n * @example /foobar/\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PPROF_PROFILE_DROP_FRAMES = 'pprof.profile.drop_frames' as const;\n\n/**\n * Frames with Function.function_name fully matching the regexp will be kept, even if it matches drop_frames.\n *\n * @example /bazinga/\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PPROF_PROFILE_KEEP_FRAMES = 'pprof.profile.keep_frames' as const;\n\n/**\n * Length of the process.command_args array\n *\n * @example 4\n *\n * @note This field can be useful for querying or performing bucket analysis on how many arguments were provided to start a process. More arguments may be an indication of suspicious activity.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_ARGS_COUNT = 'process.args_count' as const;\n\n/**\n * The command used to launch the process (i.e. the command name). On Linux based systems, can be set to the zeroth string in `proc/[pid]/cmdline`. On Windows, can be set to the first parameter extracted from `GetCommandLineW`.\n *\n * @example cmd/otelcol\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_COMMAND = 'process.command' as const;\n\n/**\n * All the command arguments (including the command/executable itself) as received by the process. On Linux-based systems (and some other Unixoid systems supporting procfs), can be set according to the list of null-delimited strings extracted from `proc/[pid]/cmdline`. For libc-based executables, this would be the full argv vector passed to `main`. **SHOULD NOT** be collected by default unless there is sanitization that excludes sensitive data.\n *\n * @example [\"cmd/otecol\", \"--config=config.yaml\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_COMMAND_ARGS = 'process.command_args' as const;\n\n/**\n * The full command used to launch the process as a single string representing the full command. On Windows, can be set to the result of `GetCommandLineW`. Do not set this if you have to assemble it just for monitoring; use `process.command_args` instead. **SHOULD NOT** be collected by default unless there is sanitization that excludes sensitive data.\n *\n * @example C:\\\\cmd\\\\otecol --config=\"my directory\\\\config.yaml\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_COMMAND_LINE = 'process.command_line' as const;\n\n/**\n * Specifies whether the context switches for this data point were voluntary or involuntary.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_CONTEXT_SWITCH_TYPE = 'process.context_switch.type' as const;\n\n/**\n * Enum value \"involuntary\" for attribute {@link ATTR_PROCESS_CONTEXT_SWITCH_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROCESS_CONTEXT_SWITCH_TYPE_VALUE_INVOLUNTARY = \"involuntary\" as const;\n\n/**\n * Enum value \"voluntary\" for attribute {@link ATTR_PROCESS_CONTEXT_SWITCH_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROCESS_CONTEXT_SWITCH_TYPE_VALUE_VOLUNTARY = \"voluntary\" as const;\n\n/**\n * Deprecated, use `cpu.mode` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `cpu.mode`.\n */\nexport const ATTR_PROCESS_CPU_STATE = 'process.cpu.state' as const;\n\n/**\n * Enum value \"system\" for attribute {@link ATTR_PROCESS_CPU_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROCESS_CPU_STATE_VALUE_SYSTEM = \"system\" as const;\n\n/**\n * Enum value \"user\" for attribute {@link ATTR_PROCESS_CPU_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROCESS_CPU_STATE_VALUE_USER = \"user\" as const;\n\n/**\n * Enum value \"wait\" for attribute {@link ATTR_PROCESS_CPU_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROCESS_CPU_STATE_VALUE_WAIT = \"wait\" as const;\n\n/**\n * The date and time the process was created, in ISO 8601 format.\n *\n * @example 2023-11-21T09:25:34.853Z\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_CREATION_TIME = 'process.creation.time' as const;\n\n/**\n * Process environment variables, `<key>` being the environment variable name, the value being the environment variable value.\n *\n * @example ubuntu\n * @example /usr/local/bin:/usr/bin\n *\n * @note Examples:\n *\n * - an environment variable `USER` with value `\"ubuntu\"` **SHOULD** be recorded\n * as the `process.environment_variable.USER` attribute with value `\"ubuntu\"`.\n * - an environment variable `PATH` with value `\"/usr/local/bin:/usr/bin\"`\n * **SHOULD** be recorded as the `process.environment_variable.PATH` attribute\n * with value `\"/usr/local/bin:/usr/bin\"`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_ENVIRONMENT_VARIABLE = (key: string) => `process.environment_variable.${key}`;\n\n/**\n * The GNU build ID as found in the `.note.gnu.build-id` ELF section (hex string).\n *\n * @example c89b11207f6479603b0d49bf291c092c2b719293\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_EXECUTABLE_BUILD_ID_GNU = 'process.executable.build_id.gnu' as const;\n\n/**\n * The Go build ID as retrieved by `go tool buildid <go executable>`.\n *\n * @example foh3mEXu7BLZjsN9pOwG/kATcXlYVCDEFouRMQed_/WwRFB1hPo9LBkekthSPG/x8hMC8emW2cCjXD0_1aY\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_EXECUTABLE_BUILD_ID_GO = 'process.executable.build_id.go' as const;\n\n/**\n * Profiling specific build ID for executables. See the OTel specification for Profiles for more information.\n *\n * @example 600DCAFE4A110000F2BF38C493F5FB92\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_EXECUTABLE_BUILD_ID_HTLHASH = 'process.executable.build_id.htlhash' as const;\n\n/**\n * \"Deprecated, use `process.executable.build_id.htlhash` instead.\"\n *\n * @example 600DCAFE4A110000F2BF38C493F5FB92\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `process.executable.build_id.htlhash`.\n */\nexport const ATTR_PROCESS_EXECUTABLE_BUILD_ID_PROFILING = 'process.executable.build_id.profiling' as const;\n\n/**\n * The name of the process executable. On Linux based systems, this **SHOULD** be set to the base name of the target of `/proc/[pid]/exe`. On Windows, this **SHOULD** be set to the base name of `GetProcessImageFileNameW`.\n *\n * @example otelcol\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_EXECUTABLE_NAME = 'process.executable.name' as const;\n\n/**\n * The full path to the process executable. On Linux based systems, can be set to the target of `proc/[pid]/exe`. On Windows, can be set to the result of `GetProcessImageFileNameW`.\n *\n * @example /usr/bin/cmd/otelcol\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_EXECUTABLE_PATH = 'process.executable.path' as const;\n\n/**\n * The exit code of the process.\n *\n * @example 127\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_EXIT_CODE = 'process.exit.code' as const;\n\n/**\n * The date and time the process exited, in ISO 8601 format.\n *\n * @example 2023-11-21T09:26:12.315Z\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_EXIT_TIME = 'process.exit.time' as const;\n\n/**\n * The PID of the process's group leader. This is also the process group ID (PGID) of the process.\n *\n * @example 23\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_GROUP_LEADER_PID = 'process.group_leader.pid' as const;\n\n/**\n * Whether the process is connected to an interactive shell.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_INTERACTIVE = 'process.interactive' as const;\n\n/**\n * The control group associated with the process.\n *\n * @example 1:name=systemd:/user.slice/user-1000.slice/session-3.scope\n * @example 0::/user.slice/user-1000.slice/user@1000.service/tmux-spawn-0267755b-4639-4a27-90ed-f19f88e53748.scope\n *\n * @note Control groups (cgroups) are a kernel feature used to organize and manage process resources. This attribute provides the path(s) to the cgroup(s) associated with the process, which should match the contents of the [/proc/[PID]/cgroup](https://man7.org/linux/man-pages/man7/cgroups.7.html) file.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_LINUX_CGROUP = 'process.linux.cgroup' as const;\n\n/**\n * The username of the user that owns the process.\n *\n * @example root\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_OWNER = 'process.owner' as const;\n\n/**\n * Deprecated, use `system.paging.fault.type` instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `system.paging.fault.type`.\n */\nexport const ATTR_PROCESS_PAGING_FAULT_TYPE = 'process.paging.fault_type' as const;\n\n/**\n * Enum value \"major\" for attribute {@link ATTR_PROCESS_PAGING_FAULT_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROCESS_PAGING_FAULT_TYPE_VALUE_MAJOR = \"major\" as const;\n\n/**\n * Enum value \"minor\" for attribute {@link ATTR_PROCESS_PAGING_FAULT_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROCESS_PAGING_FAULT_TYPE_VALUE_MINOR = \"minor\" as const;\n\n/**\n * Parent Process identifier (PPID).\n *\n * @example 111\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_PARENT_PID = 'process.parent_pid' as const;\n\n/**\n * Process identifier (PID).\n *\n * @example 1234\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_PID = 'process.pid' as const;\n\n/**\n * The real user ID (RUID) of the process.\n *\n * @example 1000\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_REAL_USER_ID = 'process.real_user.id' as const;\n\n/**\n * The username of the real user of the process.\n *\n * @example operator\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_REAL_USER_NAME = 'process.real_user.name' as const;\n\n/**\n * An additional description about the runtime of the process, for example a specific vendor customization of the runtime environment.\n *\n * @example \"Eclipse OpenJ9 Eclipse OpenJ9 VM openj9-0.21.0\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_RUNTIME_DESCRIPTION = 'process.runtime.description' as const;\n\n/**\n * The name of the runtime of this process.\n *\n * @example OpenJDK Runtime Environment\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_RUNTIME_NAME = 'process.runtime.name' as const;\n\n/**\n * The version of the runtime of this process, as returned by the runtime without modification.\n *\n * @example \"14.0.2\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_RUNTIME_VERSION = 'process.runtime.version' as const;\n\n/**\n * The saved user ID (SUID) of the process.\n *\n * @example 1002\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_SAVED_USER_ID = 'process.saved_user.id' as const;\n\n/**\n * The username of the saved user.\n *\n * @example operator\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_SAVED_USER_NAME = 'process.saved_user.name' as const;\n\n/**\n * The PID of the process's session leader. This is also the session ID (SID) of the process.\n *\n * @example 14\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_SESSION_LEADER_PID = 'process.session_leader.pid' as const;\n\n/**\n * The process state, e.g., [Linux Process State Codes](https://man7.org/linux/man-pages/man1/ps.1.html#PROCESS_STATE_CODES)\n *\n * @example running\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_STATE = 'process.state' as const;\n\n/**\n * Enum value \"defunct\" for attribute {@link ATTR_PROCESS_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROCESS_STATE_VALUE_DEFUNCT = \"defunct\" as const;\n\n/**\n * Enum value \"running\" for attribute {@link ATTR_PROCESS_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROCESS_STATE_VALUE_RUNNING = \"running\" as const;\n\n/**\n * Enum value \"sleeping\" for attribute {@link ATTR_PROCESS_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROCESS_STATE_VALUE_SLEEPING = \"sleeping\" as const;\n\n/**\n * Enum value \"stopped\" for attribute {@link ATTR_PROCESS_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROCESS_STATE_VALUE_STOPPED = \"stopped\" as const;\n\n/**\n * Process title (proctitle)\n *\n * @example cat /etc/hostname\n * @example xfce4-session\n * @example bash\n *\n * @note In many Unix-like systems, process title (proctitle), is the string that represents the name or command line of a running process, displayed by system monitoring tools like ps, top, and htop.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_TITLE = 'process.title' as const;\n\n/**\n * The effective user ID (EUID) of the process.\n *\n * @example 1001\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_USER_ID = 'process.user.id' as const;\n\n/**\n * The username of the effective user of the process.\n *\n * @example root\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_USER_NAME = 'process.user.name' as const;\n\n/**\n * Virtual process identifier.\n *\n * @example 12\n *\n * @note The process ID within a PID namespace. This is not necessarily unique across all processes on the host but it is unique within the process namespace that the process exists within.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_VPID = 'process.vpid' as const;\n\n/**\n * The working directory of the process.\n *\n * @example /root\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROCESS_WORKING_DIRECTORY = 'process.working_directory' as const;\n\n/**\n * Describes the interpreter or compiler of a single frame.\n *\n * @example cpython\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_PROFILE_FRAME_TYPE = 'profile.frame.type' as const;\n\n/**\n * Enum value \"beam\" for attribute {@link ATTR_PROFILE_FRAME_TYPE}.\n *\n * [Erlang](https://en.wikipedia.org/wiki/BEAM_(Erlang_virtual_machine))\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROFILE_FRAME_TYPE_VALUE_BEAM = \"beam\" as const;\n\n/**\n * Enum value \"cpython\" for attribute {@link ATTR_PROFILE_FRAME_TYPE}.\n *\n * [Python](https://wikipedia.org/wiki/Python_(programming_language))\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROFILE_FRAME_TYPE_VALUE_CPYTHON = \"cpython\" as const;\n\n/**\n * Enum value \"dotnet\" for attribute {@link ATTR_PROFILE_FRAME_TYPE}.\n *\n * [.NET](https://wikipedia.org/wiki/.NET)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROFILE_FRAME_TYPE_VALUE_DOTNET = \"dotnet\" as const;\n\n/**\n * Enum value \"go\" for attribute {@link ATTR_PROFILE_FRAME_TYPE}.\n *\n * [Go](https://wikipedia.org/wiki/Go_(programming_language)),\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROFILE_FRAME_TYPE_VALUE_GO = \"go\" as const;\n\n/**\n * Enum value \"jvm\" for attribute {@link ATTR_PROFILE_FRAME_TYPE}.\n *\n * [JVM](https://wikipedia.org/wiki/Java_virtual_machine)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROFILE_FRAME_TYPE_VALUE_JVM = \"jvm\" as const;\n\n/**\n * Enum value \"kernel\" for attribute {@link ATTR_PROFILE_FRAME_TYPE}.\n *\n * [Kernel](https://wikipedia.org/wiki/Kernel_(operating_system))\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROFILE_FRAME_TYPE_VALUE_KERNEL = \"kernel\" as const;\n\n/**\n * Enum value \"native\" for attribute {@link ATTR_PROFILE_FRAME_TYPE}.\n *\n * Can be one of but not limited to [C](https://wikipedia.org/wiki/C_(programming_language)), [C++](https://wikipedia.org/wiki/C%2B%2B), [Go](https://wikipedia.org/wiki/Go_(programming_language)) or [Rust](https://wikipedia.org/wiki/Rust_(programming_language)). If possible, a more precise value **MUST** be used.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROFILE_FRAME_TYPE_VALUE_NATIVE = \"native\" as const;\n\n/**\n * Enum value \"perl\" for attribute {@link ATTR_PROFILE_FRAME_TYPE}.\n *\n * [Perl](https://wikipedia.org/wiki/Perl)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROFILE_FRAME_TYPE_VALUE_PERL = \"perl\" as const;\n\n/**\n * Enum value \"php\" for attribute {@link ATTR_PROFILE_FRAME_TYPE}.\n *\n * [PHP](https://wikipedia.org/wiki/PHP)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROFILE_FRAME_TYPE_VALUE_PHP = \"php\" as const;\n\n/**\n * Enum value \"ruby\" for attribute {@link ATTR_PROFILE_FRAME_TYPE}.\n *\n * [Ruby](https://wikipedia.org/wiki/Ruby_(programming_language))\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROFILE_FRAME_TYPE_VALUE_RUBY = \"ruby\" as const;\n\n/**\n * Enum value \"rust\" for attribute {@link ATTR_PROFILE_FRAME_TYPE}.\n *\n * [Rust](https://wikipedia.org/wiki/Rust_(programming_language))\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROFILE_FRAME_TYPE_VALUE_RUST = \"rust\" as const;\n\n/**\n * Enum value \"v8js\" for attribute {@link ATTR_PROFILE_FRAME_TYPE}.\n *\n * [V8JS](https://wikipedia.org/wiki/V8_(JavaScript_engine))\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const PROFILE_FRAME_TYPE_VALUE_V8JS = \"v8js\" as const;\n\n/**\n * Deprecated, use `rpc.response.status_code` attribute instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `rpc.response.status_code`.\n */\nexport const ATTR_RPC_CONNECT_RPC_ERROR_CODE = 'rpc.connect_rpc.error_code' as const;\n\n/**\n * Enum value \"aborted\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_ABORTED = \"aborted\" as const;\n\n/**\n * Enum value \"already_exists\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_ALREADY_EXISTS = \"already_exists\" as const;\n\n/**\n * Enum value \"cancelled\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_CANCELLED = \"cancelled\" as const;\n\n/**\n * Enum value \"data_loss\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_DATA_LOSS = \"data_loss\" as const;\n\n/**\n * Enum value \"deadline_exceeded\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_DEADLINE_EXCEEDED = \"deadline_exceeded\" as const;\n\n/**\n * Enum value \"failed_precondition\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_FAILED_PRECONDITION = \"failed_precondition\" as const;\n\n/**\n * Enum value \"internal\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_INTERNAL = \"internal\" as const;\n\n/**\n * Enum value \"invalid_argument\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_INVALID_ARGUMENT = \"invalid_argument\" as const;\n\n/**\n * Enum value \"not_found\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_NOT_FOUND = \"not_found\" as const;\n\n/**\n * Enum value \"out_of_range\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_OUT_OF_RANGE = \"out_of_range\" as const;\n\n/**\n * Enum value \"permission_denied\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_PERMISSION_DENIED = \"permission_denied\" as const;\n\n/**\n * Enum value \"resource_exhausted\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_RESOURCE_EXHAUSTED = \"resource_exhausted\" as const;\n\n/**\n * Enum value \"unauthenticated\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_UNAUTHENTICATED = \"unauthenticated\" as const;\n\n/**\n * Enum value \"unavailable\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_UNAVAILABLE = \"unavailable\" as const;\n\n/**\n * Enum value \"unimplemented\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_UNIMPLEMENTED = \"unimplemented\" as const;\n\n/**\n * Enum value \"unknown\" for attribute {@link ATTR_RPC_CONNECT_RPC_ERROR_CODE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_CONNECT_RPC_ERROR_CODE_VALUE_UNKNOWN = \"unknown\" as const;\n\n/**\n * Deprecated, use `rpc.request.metadata` instead.\n *\n * @example [\"1.2.3.4\", \"1.2.3.5\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `rpc.request.metadata`.\n */\nexport const ATTR_RPC_CONNECT_RPC_REQUEST_METADATA = (key: string) => `rpc.connect_rpc.request.metadata.${key}`;\n\n/**\n * Deprecated, use `rpc.response.metadata` instead.\n *\n * @example [\"attribute_value\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `rpc.response.metadata`.\n */\nexport const ATTR_RPC_CONNECT_RPC_RESPONSE_METADATA = (key: string) => `rpc.connect_rpc.response.metadata.${key}`;\n\n/**\n * Deprecated, use `rpc.request.metadata` instead.\n *\n * @example [\"1.2.3.4\", \"1.2.3.5\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `rpc.request.metadata`.\n */\nexport const ATTR_RPC_GRPC_REQUEST_METADATA = (key: string) => `rpc.grpc.request.metadata.${key}`;\n\n/**\n * Deprecated, use `rpc.response.metadata` instead.\n *\n * @example [\"attribute_value\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `rpc.response.metadata`.\n */\nexport const ATTR_RPC_GRPC_RESPONSE_METADATA = (key: string) => `rpc.grpc.response.metadata.${key}`;\n\n/**\n * Deprecated, use string representation on the `rpc.response.status_code` attribute instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Use string representation of the gRPC status code on the `rpc.response.status_code` attribute.\n */\nexport const ATTR_RPC_GRPC_STATUS_CODE = 'rpc.grpc.status_code' as const;\n\n/**\n * Enum value 0 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * OK\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_OK = 0 as const;\n\n/**\n * Enum value 1 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * CANCELLED\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_CANCELLED = 1 as const;\n\n/**\n * Enum value 2 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * UNKNOWN\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_UNKNOWN = 2 as const;\n\n/**\n * Enum value 3 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * INVALID_ARGUMENT\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_INVALID_ARGUMENT = 3 as const;\n\n/**\n * Enum value 4 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * DEADLINE_EXCEEDED\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_DEADLINE_EXCEEDED = 4 as const;\n\n/**\n * Enum value 5 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * NOT_FOUND\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_NOT_FOUND = 5 as const;\n\n/**\n * Enum value 6 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * ALREADY_EXISTS\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_ALREADY_EXISTS = 6 as const;\n\n/**\n * Enum value 7 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * PERMISSION_DENIED\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_PERMISSION_DENIED = 7 as const;\n\n/**\n * Enum value 8 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * RESOURCE_EXHAUSTED\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_RESOURCE_EXHAUSTED = 8 as const;\n\n/**\n * Enum value 9 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * FAILED_PRECONDITION\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_FAILED_PRECONDITION = 9 as const;\n\n/**\n * Enum value 10 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * ABORTED\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_ABORTED = 10 as const;\n\n/**\n * Enum value 11 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * OUT_OF_RANGE\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_OUT_OF_RANGE = 11 as const;\n\n/**\n * Enum value 12 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * UNIMPLEMENTED\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_UNIMPLEMENTED = 12 as const;\n\n/**\n * Enum value 13 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * INTERNAL\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_INTERNAL = 13 as const;\n\n/**\n * Enum value 14 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * UNAVAILABLE\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_UNAVAILABLE = 14 as const;\n\n/**\n * Enum value 15 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * DATA_LOSS\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_DATA_LOSS = 15 as const;\n\n/**\n * Enum value 16 for attribute {@link ATTR_RPC_GRPC_STATUS_CODE}.\n *\n * UNAUTHENTICATED\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_GRPC_STATUS_CODE_VALUE_UNAUTHENTICATED = 16 as const;\n\n/**\n * Deprecated, use string representation on the `rpc.response.status_code` attribute instead.\n *\n * @example -32700\n * @example 100\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Use string representation of the error code on the `rpc.response.status_code` attribute.\n */\nexport const ATTR_RPC_JSONRPC_ERROR_CODE = 'rpc.jsonrpc.error_code' as const;\n\n/**\n * Deprecated, use span status description or `error.message` attribute on other signals.\n *\n * @example Parse error\n * @example User already exists\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Use the span status description or `error.message` attribute on other signals.\n */\nexport const ATTR_RPC_JSONRPC_ERROR_MESSAGE = 'rpc.jsonrpc.error_message' as const;\n\n/**\n * Deprecated, use `jsonrpc.request.id` instead.\n *\n * @example 10\n * @example request-7\n * @example\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `jsonrpc.request.id`.\n */\nexport const ATTR_RPC_JSONRPC_REQUEST_ID = 'rpc.jsonrpc.request_id' as const;\n\n/**\n * Deprecated, use `jsonrpc.protocol.version` instead.\n *\n * @example 2.0\n * @example 1.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `jsonrpc.protocol.version`.\n */\nexport const ATTR_RPC_JSONRPC_VERSION = 'rpc.jsonrpc.version' as const;\n\n/**\n * Compressed size of the message in bytes.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_RPC_MESSAGE_COMPRESSED_SIZE = 'rpc.message.compressed_size' as const;\n\n/**\n * **MUST** be calculated as two different counters starting from `1` one for sent messages and one for received message.\n *\n * @note This way we guarantee that the values will be consistent between different implementations.\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_RPC_MESSAGE_ID = 'rpc.message.id' as const;\n\n/**\n * Whether this is a received or sent message.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_RPC_MESSAGE_TYPE = 'rpc.message.type' as const;\n\n/**\n * Enum value \"RECEIVED\" for attribute {@link ATTR_RPC_MESSAGE_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_MESSAGE_TYPE_VALUE_RECEIVED = \"RECEIVED\" as const;\n\n/**\n * Enum value \"SENT\" for attribute {@link ATTR_RPC_MESSAGE_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_MESSAGE_TYPE_VALUE_SENT = \"SENT\" as const;\n\n/**\n * Uncompressed size of the message in bytes.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_RPC_MESSAGE_UNCOMPRESSED_SIZE = 'rpc.message.uncompressed_size' as const;\n\n/**\n * The fully-qualified logical name of the method from the RPC interface perspective.\n *\n * @example com.example.ExampleService/exampleMethod\n * @example EchoService/Echo\n * @example _OTHER\n *\n * @note The method name **MAY** have unbounded cardinality in edge or error cases.\n *\n * Some RPC frameworks or libraries provide a fixed set of recognized methods\n * for client stubs and server implementations. Instrumentations for such\n * frameworks **MUST** set this attribute to the original method name only\n * when the method is recognized by the framework or library.\n *\n * When the method is not recognized, for example, when the server receives\n * a request for a method that is not predefined on the server, or when\n * instrumentation is not able to reliably detect if the method is predefined,\n * the attribute **MUST** be set to `_OTHER`. In such cases, tracing\n * instrumentations **MUST** also set `rpc.method_original` attribute to\n * the original method value.\n *\n * If the RPC instrumentation could end up converting valid RPC methods to\n * `_OTHER`, then it **SHOULD** provide a way to configure the list of recognized\n * RPC methods.\n *\n * The `rpc.method` can be different from the name of any implementing\n * method/function.\n * The `code.function.name` attribute may be used to record the fully-qualified\n * method actually executing the call on the server side, or the\n * RPC client stub method on the client side.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_RPC_METHOD = 'rpc.method' as const;\n\n/**\n * The original name of the method used by the client.\n *\n * @example com.myservice.EchoService/catchAll\n * @example com.myservice.EchoService/unknownMethod\n * @example InvalidMethod\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_RPC_METHOD_ORIGINAL = 'rpc.method_original' as const;\n\n/**\n * RPC request metadata, `<key>` being the normalized RPC metadata key (lowercase), the value being the metadata values.\n *\n * @example [\"1.2.3.4\", \"1.2.3.5\"]\n *\n * @note Instrumentations **SHOULD** require an explicit configuration of which metadata values are to be captured.\n * Including all request metadata values can be a security risk - explicit configuration helps avoid leaking sensitive information.\n *\n * For example, a property `my-custom-key` with value `[\"1.2.3.4\", \"1.2.3.5\"]` **SHOULD** be recorded as\n * `rpc.request.metadata.my-custom-key` attribute with value `[\"1.2.3.4\", \"1.2.3.5\"]`\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_RPC_REQUEST_METADATA = (key: string) => `rpc.request.metadata.${key}`;\n\n/**\n * RPC response metadata, `<key>` being the normalized RPC metadata key (lowercase), the value being the metadata values.\n *\n * @example [\"attribute_value\"]\n *\n * @note Instrumentations **SHOULD** require an explicit configuration of which metadata values are to be captured.\n * Including all response metadata values can be a security risk - explicit configuration helps avoid leaking sensitive information.\n *\n * For example, a property `my-custom-key` with value `[\"attribute_value\"]` **SHOULD** be recorded as\n * the `rpc.response.metadata.my-custom-key` attribute with value `[\"attribute_value\"]`\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_RPC_RESPONSE_METADATA = (key: string) => `rpc.response.metadata.${key}`;\n\n/**\n * Status code of the RPC returned by the RPC server or generated by the client\n *\n * @example OK\n * @example DEADLINE_EXCEEDED\n * @example -32602\n *\n * @note Usually it represents an error code, but may also represent partial success, warning, or differentiate between various types of successful outcomes.\n * Semantic conventions for individual RPC frameworks **SHOULD** document what `rpc.response.status_code` means in the context of that system and which values are considered to represent errors.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_RPC_RESPONSE_STATUS_CODE = 'rpc.response.status_code' as const;\n\n/**\n * Deprecated, use fully-qualified `rpc.method` instead.\n *\n * @example \"myservice.EchoService\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Value should be included in `rpc.method` which is expected to be a fully-qualified name.\n */\nexport const ATTR_RPC_SERVICE = 'rpc.service' as const;\n\n/**\n * Deprecated, use `rpc.system.name` attribute instead.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `rpc.system.name`.\n */\nexport const ATTR_RPC_SYSTEM = 'rpc.system' as const;\n\n/**\n * Enum value \"apache_dubbo\" for attribute {@link ATTR_RPC_SYSTEM}.\n *\n * Apache Dubbo\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_SYSTEM_VALUE_APACHE_DUBBO = \"apache_dubbo\" as const;\n\n/**\n * Enum value \"connect_rpc\" for attribute {@link ATTR_RPC_SYSTEM}.\n *\n * Connect RPC\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_SYSTEM_VALUE_CONNECT_RPC = \"connect_rpc\" as const;\n\n/**\n * Enum value \"dotnet_wcf\" for attribute {@link ATTR_RPC_SYSTEM}.\n *\n * .NET WCF\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_SYSTEM_VALUE_DOTNET_WCF = \"dotnet_wcf\" as const;\n\n/**\n * Enum value \"grpc\" for attribute {@link ATTR_RPC_SYSTEM}.\n *\n * gRPC\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_SYSTEM_VALUE_GRPC = \"grpc\" as const;\n\n/**\n * Enum value \"java_rmi\" for attribute {@link ATTR_RPC_SYSTEM}.\n *\n * Java RMI\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_SYSTEM_VALUE_JAVA_RMI = \"java_rmi\" as const;\n\n/**\n * Enum value \"jsonrpc\" for attribute {@link ATTR_RPC_SYSTEM}.\n *\n * JSON-RPC\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_SYSTEM_VALUE_JSONRPC = \"jsonrpc\" as const;\n\n/**\n * Enum value \"onc_rpc\" for attribute {@link ATTR_RPC_SYSTEM}.\n *\n * [ONC RPC (Sun RPC)](https://datatracker.ietf.org/doc/html/rfc5531)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_SYSTEM_VALUE_ONC_RPC = \"onc_rpc\" as const;\n\n/**\n * The Remote Procedure Call (RPC) system.\n *\n * @note The client and server RPC systems may differ for the same RPC interaction. For example, a client may use Apache Dubbo or Connect RPC to communicate with a server that uses gRPC since both protocols provide compatibility with gRPC.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_RPC_SYSTEM_NAME = 'rpc.system.name' as const;\n\n/**\n * Enum value \"connectrpc\" for attribute {@link ATTR_RPC_SYSTEM_NAME}.\n *\n * [Connect RPC](https://connectrpc.com/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_SYSTEM_NAME_VALUE_CONNECTRPC = \"connectrpc\" as const;\n\n/**\n * Enum value \"dubbo\" for attribute {@link ATTR_RPC_SYSTEM_NAME}.\n *\n * [Apache Dubbo](https://dubbo.apache.org/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_SYSTEM_NAME_VALUE_DUBBO = \"dubbo\" as const;\n\n/**\n * Enum value \"grpc\" for attribute {@link ATTR_RPC_SYSTEM_NAME}.\n *\n * [gRPC](https://grpc.io/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_SYSTEM_NAME_VALUE_GRPC = \"grpc\" as const;\n\n/**\n * Enum value \"jsonrpc\" for attribute {@link ATTR_RPC_SYSTEM_NAME}.\n *\n * [JSON-RPC](https://www.jsonrpc.org/)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const RPC_SYSTEM_NAME_VALUE_JSONRPC = \"jsonrpc\" as const;\n\n/**\n * A categorization value keyword used by the entity using the rule for detection of this event\n *\n * @example Attempted Information Leak\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SECURITY_RULE_CATEGORY = 'security_rule.category' as const;\n\n/**\n * The description of the rule generating the event.\n *\n * @example Block requests to public DNS over HTTPS / TLS protocols\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SECURITY_RULE_DESCRIPTION = 'security_rule.description' as const;\n\n/**\n * Name of the license under which the rule used to generate this event is made available.\n *\n * @example Apache 2.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SECURITY_RULE_LICENSE = 'security_rule.license' as const;\n\n/**\n * The name of the rule or signature generating the event.\n *\n * @example BLOCK_DNS_over_TLS\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SECURITY_RULE_NAME = 'security_rule.name' as const;\n\n/**\n * Reference URL to additional information about the rule used to generate this event.\n *\n * @example https://en.wikipedia.org/wiki/DNS_over_TLS\n *\n * @note The URL can point to the vendor’s documentation about the rule. If that’s not available, it can also be a link to a more general page describing this type of alert.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SECURITY_RULE_REFERENCE = 'security_rule.reference' as const;\n\n/**\n * Name of the ruleset, policy, group, or parent category in which the rule used to generate this event is a member.\n *\n * @example Standard_Protocol_Filters\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SECURITY_RULE_RULESET_NAME = 'security_rule.ruleset.name' as const;\n\n/**\n * A rule ID that is unique within the scope of a set or group of agents, observers, or other entities using the rule for detection of this event.\n *\n * @example 550e8400-e29b-41d4-a716-446655440000\n * @example 1100110011\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SECURITY_RULE_UUID = 'security_rule.uuid' as const;\n\n/**\n * The version / revision of the rule being used for analysis.\n *\n * @example 1.0.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SECURITY_RULE_VERSION = 'security_rule.version' as const;\n\n/**\n * The string ID of the service instance.\n *\n * @example 627cc493-f310-47de-96bd-71410b7dec09\n *\n * @note **MUST** be unique for each instance of the same `service.namespace,service.name` pair (in other words\n * `service.namespace,service.name,service.instance.id` triplet **MUST** be globally unique). The ID helps to\n * distinguish instances of the same service that exist at the same time (e.g. instances of a horizontally scaled\n * service).\n *\n * Implementations, such as SDKs, are recommended to generate a random Version 1 or Version 4 [RFC\n * 4122](https://www.ietf.org/rfc/rfc4122.txt) UUID, but are free to use an inherent unique ID as the source of\n * this value if stability is desirable. In that case, the ID **SHOULD** be used as source of a UUID Version 5 and\n * **SHOULD** use the following UUID as the namespace: `4d63009a-8d0f-11ee-aad7-4c796ed8e320`.\n *\n * UUIDs are typically recommended, as only an opaque value for the purposes of identifying a service instance is\n * needed. Similar to what can be seen in the man page for the\n * [`/etc/machine-id`](https://www.freedesktop.org/software/systemd/man/latest/machine-id.html) file, the underlying\n * data, such as pod name and namespace should be treated as confidential, being the user's choice to expose it\n * or not via another resource attribute.\n *\n * For applications running behind an application server (like unicorn), we do not recommend using one identifier\n * for all processes participating in the application. Instead, it's recommended each division (e.g. a worker\n * thread in unicorn) to have its own instance.id.\n *\n * It's not recommended for a Collector to set `service.instance.id` if it can't unambiguously determine the\n * service instance that is generating that telemetry. For instance, creating an UUID based on `pod.name` will\n * likely be wrong, as the Collector might not know from which container within that pod the telemetry originated.\n * However, Collectors can set the `service.instance.id` if they can unambiguously determine the service instance\n * for that telemetry. This is typically the case for scraping receivers, as they know the target address and\n * port.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SERVICE_INSTANCE_ID = 'service.instance.id' as const;\n\n/**\n * A namespace for `service.name`.\n *\n * @example Shop\n *\n * @note A string value having a meaning that helps to distinguish a group of services, for example the team name that owns a group of services. `service.name` is expected to be unique within the same namespace. If `service.namespace` is not specified in the Resource then `service.name` is expected to be unique for all services that have no explicit namespace defined (so the empty/unspecified namespace is simply one more valid namespace). Zero-length namespace string is assumed equal to unspecified namespace.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SERVICE_NAMESPACE = 'service.namespace' as const;\n\n/**\n * Logical name of the service on the other side of the connection. **SHOULD** be equal to the actual [`service.name`](/docs/resource/README.md#service) resource attribute of the remote service if any.\n *\n * @example shoppingcart\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SERVICE_PEER_NAME = 'service.peer.name' as const;\n\n/**\n * Logical namespace of the service on the other side of the connection. **SHOULD** be equal to the actual [`service.namespace`](/docs/resource/README.md#service) resource attribute of the remote service if any.\n *\n * @example Shop\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SERVICE_PEER_NAMESPACE = 'service.peer.namespace' as const;\n\n/**\n * A unique id to identify a session.\n *\n * @example \"00112233-4455-6677-8899-aabbccddeeff\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SESSION_ID = 'session.id' as const;\n\n/**\n * The previous `session.id` for this user, when known.\n *\n * @example \"00112233-4455-6677-8899-aabbccddeeff\"\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SESSION_PREVIOUS_ID = 'session.previous_id' as const;\n\n/**\n * Source address - domain name if available without reverse DNS lookup; otherwise, IP address or Unix domain socket name.\n *\n * @example source.example.com\n * @example 10.1.2.80\n * @example /tmp/my.sock\n *\n * @note When observed from the destination side, and when communicating through an intermediary, `source.address` **SHOULD** represent the source address behind any intermediaries, for example proxies, if it's available.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SOURCE_ADDRESS = 'source.address' as const;\n\n/**\n * Source port number\n *\n * @example 3389\n * @example 2888\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SOURCE_PORT = 'source.port' as const;\n\n/**\n * Deprecated, use `db.client.connection.state` instead.\n *\n * @example idle\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `db.client.connection.state`.\n */\nexport const ATTR_STATE = 'state' as const;\n\n/**\n * Enum value \"idle\" for attribute {@link ATTR_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const STATE_VALUE_IDLE = \"idle\" as const;\n\n/**\n * Enum value \"used\" for attribute {@link ATTR_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const STATE_VALUE_USED = \"used\" as const;\n\n/**\n * Deprecated, use `cpu.logical_number` instead.\n *\n * @example 1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `cpu.logical_number`.\n */\nexport const ATTR_SYSTEM_CPU_LOGICAL_NUMBER = 'system.cpu.logical_number' as const;\n\n/**\n * Deprecated, use `cpu.mode` instead.\n *\n * @example idle\n * @example interrupt\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `cpu.mode`.\n */\nexport const ATTR_SYSTEM_CPU_STATE = 'system.cpu.state' as const;\n\n/**\n * Enum value \"idle\" for attribute {@link ATTR_SYSTEM_CPU_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_CPU_STATE_VALUE_IDLE = \"idle\" as const;\n\n/**\n * Enum value \"interrupt\" for attribute {@link ATTR_SYSTEM_CPU_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_CPU_STATE_VALUE_INTERRUPT = \"interrupt\" as const;\n\n/**\n * Enum value \"iowait\" for attribute {@link ATTR_SYSTEM_CPU_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_CPU_STATE_VALUE_IOWAIT = \"iowait\" as const;\n\n/**\n * Enum value \"nice\" for attribute {@link ATTR_SYSTEM_CPU_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_CPU_STATE_VALUE_NICE = \"nice\" as const;\n\n/**\n * Enum value \"steal\" for attribute {@link ATTR_SYSTEM_CPU_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_CPU_STATE_VALUE_STEAL = \"steal\" as const;\n\n/**\n * Enum value \"system\" for attribute {@link ATTR_SYSTEM_CPU_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_CPU_STATE_VALUE_SYSTEM = \"system\" as const;\n\n/**\n * Enum value \"user\" for attribute {@link ATTR_SYSTEM_CPU_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_CPU_STATE_VALUE_USER = \"user\" as const;\n\n/**\n * The device identifier\n *\n * @example (identifier)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SYSTEM_DEVICE = 'system.device' as const;\n\n/**\n * The filesystem mode\n *\n * @example rw, ro\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SYSTEM_FILESYSTEM_MODE = 'system.filesystem.mode' as const;\n\n/**\n * The filesystem mount path\n *\n * @example /mnt/data\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SYSTEM_FILESYSTEM_MOUNTPOINT = 'system.filesystem.mountpoint' as const;\n\n/**\n * The filesystem state\n *\n * @example used\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SYSTEM_FILESYSTEM_STATE = 'system.filesystem.state' as const;\n\n/**\n * Enum value \"free\" for attribute {@link ATTR_SYSTEM_FILESYSTEM_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_FILESYSTEM_STATE_VALUE_FREE = \"free\" as const;\n\n/**\n * Enum value \"reserved\" for attribute {@link ATTR_SYSTEM_FILESYSTEM_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_FILESYSTEM_STATE_VALUE_RESERVED = \"reserved\" as const;\n\n/**\n * Enum value \"used\" for attribute {@link ATTR_SYSTEM_FILESYSTEM_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_FILESYSTEM_STATE_VALUE_USED = \"used\" as const;\n\n/**\n * The filesystem type\n *\n * @example ext4\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SYSTEM_FILESYSTEM_TYPE = 'system.filesystem.type' as const;\n\n/**\n * Enum value \"exfat\" for attribute {@link ATTR_SYSTEM_FILESYSTEM_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_FILESYSTEM_TYPE_VALUE_EXFAT = \"exfat\" as const;\n\n/**\n * Enum value \"ext4\" for attribute {@link ATTR_SYSTEM_FILESYSTEM_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_FILESYSTEM_TYPE_VALUE_EXT4 = \"ext4\" as const;\n\n/**\n * Enum value \"fat32\" for attribute {@link ATTR_SYSTEM_FILESYSTEM_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_FILESYSTEM_TYPE_VALUE_FAT32 = \"fat32\" as const;\n\n/**\n * Enum value \"hfsplus\" for attribute {@link ATTR_SYSTEM_FILESYSTEM_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_FILESYSTEM_TYPE_VALUE_HFSPLUS = \"hfsplus\" as const;\n\n/**\n * Enum value \"ntfs\" for attribute {@link ATTR_SYSTEM_FILESYSTEM_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_FILESYSTEM_TYPE_VALUE_NTFS = \"ntfs\" as const;\n\n/**\n * Enum value \"refs\" for attribute {@link ATTR_SYSTEM_FILESYSTEM_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_FILESYSTEM_TYPE_VALUE_REFS = \"refs\" as const;\n\n/**\n * The Linux Slab memory state\n *\n * @example reclaimable\n * @example unreclaimable\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SYSTEM_MEMORY_LINUX_SLAB_STATE = 'system.memory.linux.slab.state' as const;\n\n/**\n * Enum value \"reclaimable\" for attribute {@link ATTR_SYSTEM_MEMORY_LINUX_SLAB_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_MEMORY_LINUX_SLAB_STATE_VALUE_RECLAIMABLE = \"reclaimable\" as const;\n\n/**\n * Enum value \"unreclaimable\" for attribute {@link ATTR_SYSTEM_MEMORY_LINUX_SLAB_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_MEMORY_LINUX_SLAB_STATE_VALUE_UNRECLAIMABLE = \"unreclaimable\" as const;\n\n/**\n * The memory state\n *\n * @example free\n * @example cached\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SYSTEM_MEMORY_STATE = 'system.memory.state' as const;\n\n/**\n * Enum value \"buffers\" for attribute {@link ATTR_SYSTEM_MEMORY_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_MEMORY_STATE_VALUE_BUFFERS = \"buffers\" as const;\n\n/**\n * Enum value \"cached\" for attribute {@link ATTR_SYSTEM_MEMORY_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_MEMORY_STATE_VALUE_CACHED = \"cached\" as const;\n\n/**\n * Enum value \"free\" for attribute {@link ATTR_SYSTEM_MEMORY_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_MEMORY_STATE_VALUE_FREE = \"free\" as const;\n\n/**\n * Enum value \"shared\" for attribute {@link ATTR_SYSTEM_MEMORY_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Removed, report shared memory usage with `metric.system.memory.shared` metric\n */\nexport const SYSTEM_MEMORY_STATE_VALUE_SHARED = \"shared\" as const;\n\n/**\n * Enum value \"used\" for attribute {@link ATTR_SYSTEM_MEMORY_STATE}.\n *\n * Actual used virtual memory in bytes.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_MEMORY_STATE_VALUE_USED = \"used\" as const;\n\n/**\n * Deprecated, use `network.connection.state` instead.\n *\n * @example close_wait\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `network.connection.state`.\n */\nexport const ATTR_SYSTEM_NETWORK_STATE = 'system.network.state' as const;\n\n/**\n * Enum value \"close\" for attribute {@link ATTR_SYSTEM_NETWORK_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_NETWORK_STATE_VALUE_CLOSE = \"close\" as const;\n\n/**\n * Enum value \"close_wait\" for attribute {@link ATTR_SYSTEM_NETWORK_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_NETWORK_STATE_VALUE_CLOSE_WAIT = \"close_wait\" as const;\n\n/**\n * Enum value \"closing\" for attribute {@link ATTR_SYSTEM_NETWORK_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_NETWORK_STATE_VALUE_CLOSING = \"closing\" as const;\n\n/**\n * Enum value \"delete\" for attribute {@link ATTR_SYSTEM_NETWORK_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_NETWORK_STATE_VALUE_DELETE = \"delete\" as const;\n\n/**\n * Enum value \"established\" for attribute {@link ATTR_SYSTEM_NETWORK_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_NETWORK_STATE_VALUE_ESTABLISHED = \"established\" as const;\n\n/**\n * Enum value \"fin_wait_1\" for attribute {@link ATTR_SYSTEM_NETWORK_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_NETWORK_STATE_VALUE_FIN_WAIT_1 = \"fin_wait_1\" as const;\n\n/**\n * Enum value \"fin_wait_2\" for attribute {@link ATTR_SYSTEM_NETWORK_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_NETWORK_STATE_VALUE_FIN_WAIT_2 = \"fin_wait_2\" as const;\n\n/**\n * Enum value \"last_ack\" for attribute {@link ATTR_SYSTEM_NETWORK_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_NETWORK_STATE_VALUE_LAST_ACK = \"last_ack\" as const;\n\n/**\n * Enum value \"listen\" for attribute {@link ATTR_SYSTEM_NETWORK_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_NETWORK_STATE_VALUE_LISTEN = \"listen\" as const;\n\n/**\n * Enum value \"syn_recv\" for attribute {@link ATTR_SYSTEM_NETWORK_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_NETWORK_STATE_VALUE_SYN_RECV = \"syn_recv\" as const;\n\n/**\n * Enum value \"syn_sent\" for attribute {@link ATTR_SYSTEM_NETWORK_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_NETWORK_STATE_VALUE_SYN_SENT = \"syn_sent\" as const;\n\n/**\n * Enum value \"time_wait\" for attribute {@link ATTR_SYSTEM_NETWORK_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_NETWORK_STATE_VALUE_TIME_WAIT = \"time_wait\" as const;\n\n/**\n * The paging access direction\n *\n * @example in\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SYSTEM_PAGING_DIRECTION = 'system.paging.direction' as const;\n\n/**\n * Enum value \"in\" for attribute {@link ATTR_SYSTEM_PAGING_DIRECTION}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PAGING_DIRECTION_VALUE_IN = \"in\" as const;\n\n/**\n * Enum value \"out\" for attribute {@link ATTR_SYSTEM_PAGING_DIRECTION}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PAGING_DIRECTION_VALUE_OUT = \"out\" as const;\n\n/**\n * The paging fault type\n *\n * @example minor\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SYSTEM_PAGING_FAULT_TYPE = 'system.paging.fault.type' as const;\n\n/**\n * Enum value \"major\" for attribute {@link ATTR_SYSTEM_PAGING_FAULT_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PAGING_FAULT_TYPE_VALUE_MAJOR = \"major\" as const;\n\n/**\n * Enum value \"minor\" for attribute {@link ATTR_SYSTEM_PAGING_FAULT_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PAGING_FAULT_TYPE_VALUE_MINOR = \"minor\" as const;\n\n/**\n * The memory paging state\n *\n * @example free\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_SYSTEM_PAGING_STATE = 'system.paging.state' as const;\n\n/**\n * Enum value \"free\" for attribute {@link ATTR_SYSTEM_PAGING_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PAGING_STATE_VALUE_FREE = \"free\" as const;\n\n/**\n * Enum value \"used\" for attribute {@link ATTR_SYSTEM_PAGING_STATE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PAGING_STATE_VALUE_USED = \"used\" as const;\n\n/**\n * Deprecated, use `system.paging.fault.type` instead.\n *\n * @example minor\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `system.paging.fault.type`.\n */\nexport const ATTR_SYSTEM_PAGING_TYPE = 'system.paging.type' as const;\n\n/**\n * Enum value \"major\" for attribute {@link ATTR_SYSTEM_PAGING_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PAGING_TYPE_VALUE_MAJOR = \"major\" as const;\n\n/**\n * Enum value \"minor\" for attribute {@link ATTR_SYSTEM_PAGING_TYPE}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PAGING_TYPE_VALUE_MINOR = \"minor\" as const;\n\n/**\n * Deprecated, use `process.state` instead.\n *\n * @example running\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `process.state`.\n */\nexport const ATTR_SYSTEM_PROCESS_STATUS = 'system.process.status' as const;\n\n/**\n * Enum value \"defunct\" for attribute {@link ATTR_SYSTEM_PROCESS_STATUS}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PROCESS_STATUS_VALUE_DEFUNCT = \"defunct\" as const;\n\n/**\n * Enum value \"running\" for attribute {@link ATTR_SYSTEM_PROCESS_STATUS}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PROCESS_STATUS_VALUE_RUNNING = \"running\" as const;\n\n/**\n * Enum value \"sleeping\" for attribute {@link ATTR_SYSTEM_PROCESS_STATUS}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PROCESS_STATUS_VALUE_SLEEPING = \"sleeping\" as const;\n\n/**\n * Enum value \"stopped\" for attribute {@link ATTR_SYSTEM_PROCESS_STATUS}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PROCESS_STATUS_VALUE_STOPPED = \"stopped\" as const;\n\n/**\n * Deprecated, use `process.state` instead.\n *\n * @example running\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `process.state`.\n */\nexport const ATTR_SYSTEM_PROCESSES_STATUS = 'system.processes.status' as const;\n\n/**\n * Enum value \"defunct\" for attribute {@link ATTR_SYSTEM_PROCESSES_STATUS}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PROCESSES_STATUS_VALUE_DEFUNCT = \"defunct\" as const;\n\n/**\n * Enum value \"running\" for attribute {@link ATTR_SYSTEM_PROCESSES_STATUS}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PROCESSES_STATUS_VALUE_RUNNING = \"running\" as const;\n\n/**\n * Enum value \"sleeping\" for attribute {@link ATTR_SYSTEM_PROCESSES_STATUS}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PROCESSES_STATUS_VALUE_SLEEPING = \"sleeping\" as const;\n\n/**\n * Enum value \"stopped\" for attribute {@link ATTR_SYSTEM_PROCESSES_STATUS}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const SYSTEM_PROCESSES_STATUS_VALUE_STOPPED = \"stopped\" as const;\n\n/**\n * The name of the auto instrumentation agent or distribution, if used.\n *\n * @example parts-unlimited-java\n *\n * @note Official auto instrumentation agents and distributions **SHOULD** set the `telemetry.distro.name` attribute to\n * a string starting with `opentelemetry-`, e.g. `opentelemetry-java-instrumentation`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TELEMETRY_DISTRO_NAME = 'telemetry.distro.name' as const;\n\n/**\n * The version string of the auto instrumentation agent or distribution, if used.\n *\n * @example 1.2.3\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TELEMETRY_DISTRO_VERSION = 'telemetry.distro.version' as const;\n\n/**\n * The fully qualified human readable name of the [test case](https://wikipedia.org/wiki/Test_case).\n *\n * @example org.example.TestCase1.test1\n * @example example/tests/TestCase1.test1\n * @example ExampleTestCase1_test1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TEST_CASE_NAME = 'test.case.name' as const;\n\n/**\n * The status of the actual test case result from test execution.\n *\n * @example pass\n * @example fail\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TEST_CASE_RESULT_STATUS = 'test.case.result.status' as const;\n\n/**\n * Enum value \"fail\" for attribute {@link ATTR_TEST_CASE_RESULT_STATUS}.\n *\n * fail\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const TEST_CASE_RESULT_STATUS_VALUE_FAIL = \"fail\" as const;\n\n/**\n * Enum value \"pass\" for attribute {@link ATTR_TEST_CASE_RESULT_STATUS}.\n *\n * pass\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const TEST_CASE_RESULT_STATUS_VALUE_PASS = \"pass\" as const;\n\n/**\n * The human readable name of a [test suite](https://wikipedia.org/wiki/Test_suite).\n *\n * @example TestSuite1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TEST_SUITE_NAME = 'test.suite.name' as const;\n\n/**\n * The status of the test suite run.\n *\n * @example success\n * @example failure\n * @example skipped\n * @example aborted\n * @example timed_out\n * @example in_progress\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TEST_SUITE_RUN_STATUS = 'test.suite.run.status' as const;\n\n/**\n * Enum value \"aborted\" for attribute {@link ATTR_TEST_SUITE_RUN_STATUS}.\n *\n * aborted\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const TEST_SUITE_RUN_STATUS_VALUE_ABORTED = \"aborted\" as const;\n\n/**\n * Enum value \"failure\" for attribute {@link ATTR_TEST_SUITE_RUN_STATUS}.\n *\n * failure\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const TEST_SUITE_RUN_STATUS_VALUE_FAILURE = \"failure\" as const;\n\n/**\n * Enum value \"in_progress\" for attribute {@link ATTR_TEST_SUITE_RUN_STATUS}.\n *\n * in_progress\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const TEST_SUITE_RUN_STATUS_VALUE_IN_PROGRESS = \"in_progress\" as const;\n\n/**\n * Enum value \"skipped\" for attribute {@link ATTR_TEST_SUITE_RUN_STATUS}.\n *\n * skipped\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const TEST_SUITE_RUN_STATUS_VALUE_SKIPPED = \"skipped\" as const;\n\n/**\n * Enum value \"success\" for attribute {@link ATTR_TEST_SUITE_RUN_STATUS}.\n *\n * success\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const TEST_SUITE_RUN_STATUS_VALUE_SUCCESS = \"success\" as const;\n\n/**\n * Enum value \"timed_out\" for attribute {@link ATTR_TEST_SUITE_RUN_STATUS}.\n *\n * timed_out\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const TEST_SUITE_RUN_STATUS_VALUE_TIMED_OUT = \"timed_out\" as const;\n\n/**\n * Current \"managed\" thread ID (as opposed to OS thread ID).\n *\n * @example 42\n *\n * @note\n * Examples of where the value can be extracted from:\n *\n * | Language or platform | Source |\n * | --- | --- |\n * | JVM | `Thread.currentThread().threadId()` |\n * | .NET | `Thread.CurrentThread.ManagedThreadId` |\n * | Python | `threading.current_thread().ident` |\n * | Ruby | `Thread.current.object_id` |\n * | C++ | `std::this_thread::get_id()` |\n * | Erlang | `erlang:self()` |\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_THREAD_ID = 'thread.id' as const;\n\n/**\n * Current thread name.\n *\n * @example \"main\"\n *\n * @note\n * Examples of where the value can be extracted from:\n *\n * | Language or platform | Source |\n * | --- | --- |\n * | JVM | `Thread.currentThread().getName()` |\n * | .NET | `Thread.CurrentThread.Name` |\n * | Python | `threading.current_thread().name` |\n * | Ruby | `Thread.current.name` |\n * | Erlang | `erlang:process_info(self(), registered_name)` |\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_THREAD_NAME = 'thread.name' as const;\n\n/**\n * String indicating the [cipher](https://datatracker.ietf.org/doc/html/rfc5246#appendix-A.5) used during the current connection.\n *\n * @example TLS_RSA_WITH_3DES_EDE_CBC_SHA\n * @example TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256\n *\n * @note The values allowed for `tls.cipher` **MUST** be one of the `Descriptions` of the [registered TLS Cipher Suits](https://www.iana.org/assignments/tls-parameters/tls-parameters.xhtml#table-tls-parameters-4).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CIPHER = 'tls.cipher' as const;\n\n/**\n * PEM-encoded stand-alone certificate offered by the client. This is usually mutually-exclusive of `client.certificate_chain` since this value also exists in that list.\n *\n * @example MII...\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CLIENT_CERTIFICATE = 'tls.client.certificate' as const;\n\n/**\n * Array of PEM-encoded certificates that make up the certificate chain offered by the client. This is usually mutually-exclusive of `client.certificate` since that value should be the first certificate in the chain.\n *\n * @example [\"MII...\", \"MI...\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CLIENT_CERTIFICATE_CHAIN = 'tls.client.certificate_chain' as const;\n\n/**\n * Certificate fingerprint using the MD5 digest of DER-encoded version of certificate offered by the client. For consistency with other hash values, this value should be formatted as an uppercase hash.\n *\n * @example 0F76C7F2C55BFD7D8E8B8F4BFBF0C9EC\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CLIENT_HASH_MD5 = 'tls.client.hash.md5' as const;\n\n/**\n * Certificate fingerprint using the SHA1 digest of DER-encoded version of certificate offered by the client. For consistency with other hash values, this value should be formatted as an uppercase hash.\n *\n * @example 9E393D93138888D288266C2D915214D1D1CCEB2A\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CLIENT_HASH_SHA1 = 'tls.client.hash.sha1' as const;\n\n/**\n * Certificate fingerprint using the SHA256 digest of DER-encoded version of certificate offered by the client. For consistency with other hash values, this value should be formatted as an uppercase hash.\n *\n * @example 0687F666A054EF17A08E2F2162EAB4CBC0D265E1D7875BE74BF3C712CA92DAF0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CLIENT_HASH_SHA256 = 'tls.client.hash.sha256' as const;\n\n/**\n * Distinguished name of [subject](https://datatracker.ietf.org/doc/html/rfc5280#section-4.1.2.6) of the issuer of the x.509 certificate presented by the client.\n *\n * @example CN=Example Root CA, OU=Infrastructure Team, DC=example, DC=com\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CLIENT_ISSUER = 'tls.client.issuer' as const;\n\n/**\n * A hash that identifies clients based on how they perform an SSL/TLS handshake.\n *\n * @example d4e5b18d6b55c71272893221c96ba240\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CLIENT_JA3 = 'tls.client.ja3' as const;\n\n/**\n * Date/Time indicating when client certificate is no longer considered valid.\n *\n * @example 2021-01-01T00:00:00.000Z\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CLIENT_NOT_AFTER = 'tls.client.not_after' as const;\n\n/**\n * Date/Time indicating when client certificate is first considered valid.\n *\n * @example 1970-01-01T00:00:00.000Z\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CLIENT_NOT_BEFORE = 'tls.client.not_before' as const;\n\n/**\n * Deprecated, use `server.address` instead.\n *\n * @example opentelemetry.io\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `server.address`.\n */\nexport const ATTR_TLS_CLIENT_SERVER_NAME = 'tls.client.server_name' as const;\n\n/**\n * Distinguished name of subject of the x.509 certificate presented by the client.\n *\n * @example CN=myclient, OU=Documentation Team, DC=example, DC=com\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CLIENT_SUBJECT = 'tls.client.subject' as const;\n\n/**\n * Array of ciphers offered by the client during the client hello.\n *\n * @example [\"TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384\", \"TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CLIENT_SUPPORTED_CIPHERS = 'tls.client.supported_ciphers' as const;\n\n/**\n * String indicating the curve used for the given cipher, when applicable\n *\n * @example secp256r1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_CURVE = 'tls.curve' as const;\n\n/**\n * Boolean flag indicating if the TLS negotiation was successful and transitioned to an encrypted tunnel.\n *\n * @example true\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_ESTABLISHED = 'tls.established' as const;\n\n/**\n * String indicating the protocol being tunneled. Per the values in the [IANA registry](https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids), this string should be lower case.\n *\n * @example http/1.1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_NEXT_PROTOCOL = 'tls.next_protocol' as const;\n\n/**\n * Normalized lowercase protocol name parsed from original string of the negotiated [SSL/TLS protocol version](https://docs.openssl.org/1.1.1/man3/SSL_get_version/#return-values)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_PROTOCOL_NAME = 'tls.protocol.name' as const;\n\n/**\n * Enum value \"ssl\" for attribute {@link ATTR_TLS_PROTOCOL_NAME}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const TLS_PROTOCOL_NAME_VALUE_SSL = \"ssl\" as const;\n\n/**\n * Enum value \"tls\" for attribute {@link ATTR_TLS_PROTOCOL_NAME}.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const TLS_PROTOCOL_NAME_VALUE_TLS = \"tls\" as const;\n\n/**\n * Numeric part of the version parsed from the original string of the negotiated [SSL/TLS protocol version](https://docs.openssl.org/1.1.1/man3/SSL_get_version/#return-values)\n *\n * @example 1.2\n * @example 3\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_PROTOCOL_VERSION = 'tls.protocol.version' as const;\n\n/**\n * Boolean flag indicating if this TLS connection was resumed from an existing TLS negotiation.\n *\n * @example true\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_RESUMED = 'tls.resumed' as const;\n\n/**\n * PEM-encoded stand-alone certificate offered by the server. This is usually mutually-exclusive of `server.certificate_chain` since this value also exists in that list.\n *\n * @example MII...\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_SERVER_CERTIFICATE = 'tls.server.certificate' as const;\n\n/**\n * Array of PEM-encoded certificates that make up the certificate chain offered by the server. This is usually mutually-exclusive of `server.certificate` since that value should be the first certificate in the chain.\n *\n * @example [\"MII...\", \"MI...\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_SERVER_CERTIFICATE_CHAIN = 'tls.server.certificate_chain' as const;\n\n/**\n * Certificate fingerprint using the MD5 digest of DER-encoded version of certificate offered by the server. For consistency with other hash values, this value should be formatted as an uppercase hash.\n *\n * @example 0F76C7F2C55BFD7D8E8B8F4BFBF0C9EC\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_SERVER_HASH_MD5 = 'tls.server.hash.md5' as const;\n\n/**\n * Certificate fingerprint using the SHA1 digest of DER-encoded version of certificate offered by the server. For consistency with other hash values, this value should be formatted as an uppercase hash.\n *\n * @example 9E393D93138888D288266C2D915214D1D1CCEB2A\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_SERVER_HASH_SHA1 = 'tls.server.hash.sha1' as const;\n\n/**\n * Certificate fingerprint using the SHA256 digest of DER-encoded version of certificate offered by the server. For consistency with other hash values, this value should be formatted as an uppercase hash.\n *\n * @example 0687F666A054EF17A08E2F2162EAB4CBC0D265E1D7875BE74BF3C712CA92DAF0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_SERVER_HASH_SHA256 = 'tls.server.hash.sha256' as const;\n\n/**\n * Distinguished name of [subject](https://datatracker.ietf.org/doc/html/rfc5280#section-4.1.2.6) of the issuer of the x.509 certificate presented by the client.\n *\n * @example CN=Example Root CA, OU=Infrastructure Team, DC=example, DC=com\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_SERVER_ISSUER = 'tls.server.issuer' as const;\n\n/**\n * A hash that identifies servers based on how they perform an SSL/TLS handshake.\n *\n * @example d4e5b18d6b55c71272893221c96ba240\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_SERVER_JA3S = 'tls.server.ja3s' as const;\n\n/**\n * Date/Time indicating when server certificate is no longer considered valid.\n *\n * @example 2021-01-01T00:00:00.000Z\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_SERVER_NOT_AFTER = 'tls.server.not_after' as const;\n\n/**\n * Date/Time indicating when server certificate is first considered valid.\n *\n * @example 1970-01-01T00:00:00.000Z\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_SERVER_NOT_BEFORE = 'tls.server.not_before' as const;\n\n/**\n * Distinguished name of subject of the x.509 certificate presented by the server.\n *\n * @example CN=myserver, OU=Documentation Team, DC=example, DC=com\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_TLS_SERVER_SUBJECT = 'tls.server.subject' as const;\n\n/**\n * Domain extracted from the `url.full`, such as \"opentelemetry.io\".\n *\n * @example www.foo.bar\n * @example opentelemetry.io\n * @example 3.12.167.2\n * @example [1080:0:0:0:8:800:200C:417A]\n *\n * @note In some cases a URL may refer to an IP and/or port directly, without a domain name. In this case, the IP address would go to the domain field. If the URL contains a [literal IPv6 address](https://www.rfc-editor.org/rfc/rfc2732#section-2) enclosed by `[` and `]`, the `[` and `]` characters should also be captured in the domain field.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_URL_DOMAIN = 'url.domain' as const;\n\n/**\n * The file extension extracted from the `url.full`, excluding the leading dot.\n *\n * @example png\n * @example gz\n *\n * @note The file extension is only set if it exists, as not every url has a file extension. When the file name has multiple extensions `example.tar.gz`, only the last one should be captured `gz`, not `tar.gz`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_URL_EXTENSION = 'url.extension' as const;\n\n/**\n * Unmodified original URL as seen in the event source.\n *\n * @example https://www.foo.bar/search?q=OpenTelemetry#SemConv\n * @example search?q=OpenTelemetry\n *\n * @note In network monitoring, the observed URL may be a full URL, whereas in access logs, the URL is often just represented as a path. This field is meant to represent the URL as it was observed, complete or not.\n * `url.original` might contain credentials passed via URL in form of `https://username:password@www.example.com/`. In such case password and username **SHOULD NOT** be redacted and attribute's value **SHOULD** remain the same.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_URL_ORIGINAL = 'url.original' as const;\n\n/**\n * Port extracted from the `url.full`\n *\n * @example 443\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_URL_PORT = 'url.port' as const;\n\n/**\n * The highest registered url domain, stripped of the subdomain.\n *\n * @example example.com\n * @example foo.co.uk\n *\n * @note This value can be determined precisely with the [public suffix list](https://publicsuffix.org/). For example, the registered domain for `foo.example.com` is `example.com`. Trying to approximate this by simply taking the last two labels will not work well for TLDs such as `co.uk`.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_URL_REGISTERED_DOMAIN = 'url.registered_domain' as const;\n\n/**\n * The subdomain portion of a fully qualified domain name includes all of the names except the host name under the registered_domain. In a partially qualified domain, or if the qualification level of the full name cannot be determined, subdomain contains all of the names below the registered domain.\n *\n * @example east\n * @example sub2.sub1\n *\n * @note The subdomain portion of `www.east.mydomain.co.uk` is `east`. If the domain has multiple levels of subdomain, such as `sub2.sub1.example.com`, the subdomain field should contain `sub2.sub1`, with no trailing period.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_URL_SUBDOMAIN = 'url.subdomain' as const;\n\n/**\n * The low-cardinality template of an [absolute path reference](https://www.rfc-editor.org/rfc/rfc3986#section-4.2).\n *\n * @example /users/{id}\n * @example /users/:id\n * @example /users?id={id}\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_URL_TEMPLATE = 'url.template' as const;\n\n/**\n * The effective top level domain (eTLD), also known as the domain suffix, is the last part of the domain name. For example, the top level domain for example.com is `com`.\n *\n * @example com\n * @example co.uk\n *\n * @note This value can be determined precisely with the [public suffix list](https://publicsuffix.org/).\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_URL_TOP_LEVEL_DOMAIN = 'url.top_level_domain' as const;\n\n/**\n * User email address.\n *\n * @example a.einstein@example.com\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_USER_EMAIL = 'user.email' as const;\n\n/**\n * User's full name\n *\n * @example Albert Einstein\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_USER_FULL_NAME = 'user.full_name' as const;\n\n/**\n * Unique user hash to correlate information for a user in anonymized form.\n *\n * @example 364fc68eaf4c8acec74a4e52d7d1feaa\n *\n * @note Useful if `user.id` or `user.name` contain confidential information and cannot be used.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_USER_HASH = 'user.hash' as const;\n\n/**\n * Unique identifier of the user.\n *\n * @example S-1-5-21-202424912787-2692429404-2351956786-1000\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_USER_ID = 'user.id' as const;\n\n/**\n * Short name or login/username of the user.\n *\n * @example a.einstein\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_USER_NAME = 'user.name' as const;\n\n/**\n * Array of user roles at the time of the event.\n *\n * @example [\"admin\", \"reporting_user\"]\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_USER_ROLES = 'user.roles' as const;\n\n/**\n * Name of the user-agent extracted from original. Usually refers to the browser's name.\n *\n * @example Safari\n * @example YourApp\n *\n * @note [Example](https://uaparser.dev/#demo) of extracting browser's name from original string. In the case of using a user-agent for non-browser products, such as microservices with multiple names/versions inside the `user_agent.original`, the most significant name **SHOULD** be selected. In such a scenario it should align with `user_agent.version`\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_USER_AGENT_NAME = 'user_agent.name' as const;\n\n/**\n * Human readable operating system name.\n *\n * @example iOS\n * @example Android\n * @example Ubuntu\n *\n * @note For mapping user agent strings to OS names, libraries such as [ua-parser](https://github.com/ua-parser) can be utilized.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_USER_AGENT_OS_NAME = 'user_agent.os.name' as const;\n\n/**\n * The version string of the operating system as defined in [Version Attributes](/docs/resource/README.md#version-attributes).\n *\n * @example 14.2.1\n * @example 18.04.1\n *\n * @note For mapping user agent strings to OS versions, libraries such as [ua-parser](https://github.com/ua-parser) can be utilized.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_USER_AGENT_OS_VERSION = 'user_agent.os.version' as const;\n\n/**\n * Specifies the category of synthetic traffic, such as tests or bots.\n *\n * @note This attribute **MAY** be derived from the contents of the `user_agent.original` attribute. Components that populate the attribute are responsible for determining what they consider to be synthetic bot or test traffic. This attribute can either be set for self-identification purposes, or on telemetry detected to be generated as a result of a synthetic request. This attribute is useful for distinguishing between genuine client traffic and synthetic traffic generated by bots or tests.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_USER_AGENT_SYNTHETIC_TYPE = 'user_agent.synthetic.type' as const;\n\n/**\n * Enum value \"bot\" for attribute {@link ATTR_USER_AGENT_SYNTHETIC_TYPE}.\n *\n * Bot source.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const USER_AGENT_SYNTHETIC_TYPE_VALUE_BOT = \"bot\" as const;\n\n/**\n * Enum value \"test\" for attribute {@link ATTR_USER_AGENT_SYNTHETIC_TYPE}.\n *\n * Synthetic test source.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const USER_AGENT_SYNTHETIC_TYPE_VALUE_TEST = \"test\" as const;\n\n/**\n * Version of the user-agent extracted from original. Usually refers to the browser's version\n *\n * @example 14.1.2\n * @example 1.0.0\n *\n * @note [Example](https://uaparser.dev/#demo) of extracting browser's version from original string. In the case of using a user-agent for non-browser products, such as microservices with multiple names/versions inside the `user_agent.original`, the most significant version **SHOULD** be selected. In such a scenario it should align with `user_agent.name`\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_USER_AGENT_VERSION = 'user_agent.version' as const;\n\n/**\n * The type of garbage collection.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_V8JS_GC_TYPE = 'v8js.gc.type' as const;\n\n/**\n * Enum value \"incremental\" for attribute {@link ATTR_V8JS_GC_TYPE}.\n *\n * Incremental (Incremental Marking).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const V8JS_GC_TYPE_VALUE_INCREMENTAL = \"incremental\" as const;\n\n/**\n * Enum value \"major\" for attribute {@link ATTR_V8JS_GC_TYPE}.\n *\n * Major (Mark Sweep Compact).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const V8JS_GC_TYPE_VALUE_MAJOR = \"major\" as const;\n\n/**\n * Enum value \"minor\" for attribute {@link ATTR_V8JS_GC_TYPE}.\n *\n * Minor (Scavenge).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const V8JS_GC_TYPE_VALUE_MINOR = \"minor\" as const;\n\n/**\n * Enum value \"weakcb\" for attribute {@link ATTR_V8JS_GC_TYPE}.\n *\n * Weak Callbacks (Process Weak Callbacks).\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const V8JS_GC_TYPE_VALUE_WEAKCB = \"weakcb\" as const;\n\n/**\n * The name of the space type of heap memory.\n *\n * @note Value can be retrieved from value `space_name` of [`v8.getHeapSpaceStatistics()`](https://nodejs.org/api/v8.html#v8getheapspacestatistics)\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_V8JS_HEAP_SPACE_NAME = 'v8js.heap.space.name' as const;\n\n/**\n * Enum value \"code_space\" for attribute {@link ATTR_V8JS_HEAP_SPACE_NAME}.\n *\n * Code memory space.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const V8JS_HEAP_SPACE_NAME_VALUE_CODE_SPACE = \"code_space\" as const;\n\n/**\n * Enum value \"large_object_space\" for attribute {@link ATTR_V8JS_HEAP_SPACE_NAME}.\n *\n * Large object memory space.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const V8JS_HEAP_SPACE_NAME_VALUE_LARGE_OBJECT_SPACE = \"large_object_space\" as const;\n\n/**\n * Enum value \"map_space\" for attribute {@link ATTR_V8JS_HEAP_SPACE_NAME}.\n *\n * Map memory space.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const V8JS_HEAP_SPACE_NAME_VALUE_MAP_SPACE = \"map_space\" as const;\n\n/**\n * Enum value \"new_space\" for attribute {@link ATTR_V8JS_HEAP_SPACE_NAME}.\n *\n * New memory space.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const V8JS_HEAP_SPACE_NAME_VALUE_NEW_SPACE = \"new_space\" as const;\n\n/**\n * Enum value \"old_space\" for attribute {@link ATTR_V8JS_HEAP_SPACE_NAME}.\n *\n * Old memory space.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const V8JS_HEAP_SPACE_NAME_VALUE_OLD_SPACE = \"old_space\" as const;\n\n/**\n * The ID of the change (pull request/merge request/changelist) if applicable. This is usually a unique (within repository) identifier generated by the VCS system.\n *\n * @example 123\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_CHANGE_ID = 'vcs.change.id' as const;\n\n/**\n * The state of the change (pull request/merge request/changelist).\n *\n * @example open\n * @example closed\n * @example merged\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_CHANGE_STATE = 'vcs.change.state' as const;\n\n/**\n * Enum value \"closed\" for attribute {@link ATTR_VCS_CHANGE_STATE}.\n *\n * Closed means the merge request has been closed without merging. This can happen for various reasons, such as the changes being deemed unnecessary, the issue being resolved in another way, or the author deciding to withdraw the request.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_CHANGE_STATE_VALUE_CLOSED = \"closed\" as const;\n\n/**\n * Enum value \"merged\" for attribute {@link ATTR_VCS_CHANGE_STATE}.\n *\n * Merged indicates that the change has been successfully integrated into the target codebase.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_CHANGE_STATE_VALUE_MERGED = \"merged\" as const;\n\n/**\n * Enum value \"open\" for attribute {@link ATTR_VCS_CHANGE_STATE}.\n *\n * Open means the change is currently active and under review. It hasn't been merged into the target branch yet, and it's still possible to make changes or add comments.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_CHANGE_STATE_VALUE_OPEN = \"open\" as const;\n\n/**\n * Enum value \"wip\" for attribute {@link ATTR_VCS_CHANGE_STATE}.\n *\n * WIP (work-in-progress, draft) means the change is still in progress and not yet ready for a full review. It might still undergo significant changes.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_CHANGE_STATE_VALUE_WIP = \"wip\" as const;\n\n/**\n * The human readable title of the change (pull request/merge request/changelist). This title is often a brief summary of the change and may get merged in to a ref as the commit summary.\n *\n * @example Fixes broken thing\n * @example feat: add my new feature\n * @example [chore] update dependency\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_CHANGE_TITLE = 'vcs.change.title' as const;\n\n/**\n * The type of line change being measured on a branch or change.\n *\n * @example added\n * @example removed\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_LINE_CHANGE_TYPE = 'vcs.line_change.type' as const;\n\n/**\n * Enum value \"added\" for attribute {@link ATTR_VCS_LINE_CHANGE_TYPE}.\n *\n * How many lines were added.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_LINE_CHANGE_TYPE_VALUE_ADDED = \"added\" as const;\n\n/**\n * Enum value \"removed\" for attribute {@link ATTR_VCS_LINE_CHANGE_TYPE}.\n *\n * How many lines were removed.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_LINE_CHANGE_TYPE_VALUE_REMOVED = \"removed\" as const;\n\n/**\n * The group owner within the version control system.\n *\n * @example my-org\n * @example myteam\n * @example business-unit\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_OWNER_NAME = 'vcs.owner.name' as const;\n\n/**\n * The name of the version control system provider.\n *\n * @example github\n * @example gitlab\n * @example gitea\n * @example bitbucket\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_PROVIDER_NAME = 'vcs.provider.name' as const;\n\n/**\n * Enum value \"bitbucket\" for attribute {@link ATTR_VCS_PROVIDER_NAME}.\n *\n * [Bitbucket](https://bitbucket.org)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_PROVIDER_NAME_VALUE_BITBUCKET = \"bitbucket\" as const;\n\n/**\n * Enum value \"gitea\" for attribute {@link ATTR_VCS_PROVIDER_NAME}.\n *\n * [Gitea](https://gitea.io)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_PROVIDER_NAME_VALUE_GITEA = \"gitea\" as const;\n\n/**\n * Enum value \"github\" for attribute {@link ATTR_VCS_PROVIDER_NAME}.\n *\n * [GitHub](https://github.com)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_PROVIDER_NAME_VALUE_GITHUB = \"github\" as const;\n\n/**\n * Enum value \"gitlab\" for attribute {@link ATTR_VCS_PROVIDER_NAME}.\n *\n * [GitLab](https://gitlab.com)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_PROVIDER_NAME_VALUE_GITLAB = \"gitlab\" as const;\n\n/**\n * Enum value \"gittea\" for attribute {@link ATTR_VCS_PROVIDER_NAME}.\n *\n * Deprecated, use `gitea` instead.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `gitea`.\n */\nexport const VCS_PROVIDER_NAME_VALUE_GITTEA = \"gittea\" as const;\n\n/**\n * The name of the [reference](https://git-scm.com/docs/gitglossary#def_ref) such as **branch** or **tag** in the repository.\n *\n * @example my-feature-branch\n * @example tag-1-test\n *\n * @note `base` refers to the starting point of a change. For example, `main`\n * would be the base reference of type branch if you've created a new\n * reference of type branch from it and created new commits.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_REF_BASE_NAME = 'vcs.ref.base.name' as const;\n\n/**\n * The revision, literally [revised version](https://www.merriam-webster.com/dictionary/revision), The revision most often refers to a commit object in Git, or a revision number in SVN.\n *\n * @example 9d59409acf479dfa0df1aa568182e43e43df8bbe28d60fcf2bc52e30068802cc\n * @example main\n * @example 123\n * @example HEAD\n *\n * @note `base` refers to the starting point of a change. For example, `main`\n * would be the base reference of type branch if you've created a new\n * reference of type branch from it and created new commits. The\n * revision can be a full [hash value (see\n * glossary)](https://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.186-5.pdf),\n * of the recorded change to a ref within a repository pointing to a\n * commit [commit](https://git-scm.com/docs/git-commit) object. It does\n * not necessarily have to be a hash; it can simply define a [revision\n * number](https://svnbook.red-bean.com/en/1.7/svn.tour.revs.specifiers.html)\n * which is an integer that is monotonically increasing. In cases where\n * it is identical to the `ref.base.name`, it **SHOULD** still be included.\n * It is up to the implementer to decide which value to set as the\n * revision based on the VCS system and situational context.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_REF_BASE_REVISION = 'vcs.ref.base.revision' as const;\n\n/**\n * The type of the [reference](https://git-scm.com/docs/gitglossary#def_ref) in the repository.\n *\n * @example branch\n * @example tag\n *\n * @note `base` refers to the starting point of a change. For example, `main`\n * would be the base reference of type branch if you've created a new\n * reference of type branch from it and created new commits.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_REF_BASE_TYPE = 'vcs.ref.base.type' as const;\n\n/**\n * Enum value \"branch\" for attribute {@link ATTR_VCS_REF_BASE_TYPE}.\n *\n * [branch](https://git-scm.com/docs/gitglossary#Documentation/gitglossary.txt-aiddefbranchabranch)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_REF_BASE_TYPE_VALUE_BRANCH = \"branch\" as const;\n\n/**\n * Enum value \"tag\" for attribute {@link ATTR_VCS_REF_BASE_TYPE}.\n *\n * [tag](https://git-scm.com/docs/gitglossary#Documentation/gitglossary.txt-aiddeftagatag)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_REF_BASE_TYPE_VALUE_TAG = \"tag\" as const;\n\n/**\n * The name of the [reference](https://git-scm.com/docs/gitglossary#def_ref) such as **branch** or **tag** in the repository.\n *\n * @example my-feature-branch\n * @example tag-1-test\n *\n * @note `head` refers to where you are right now; the current reference at a\n * given time.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_REF_HEAD_NAME = 'vcs.ref.head.name' as const;\n\n/**\n * The revision, literally [revised version](https://www.merriam-webster.com/dictionary/revision), The revision most often refers to a commit object in Git, or a revision number in SVN.\n *\n * @example 9d59409acf479dfa0df1aa568182e43e43df8bbe28d60fcf2bc52e30068802cc\n * @example main\n * @example 123\n * @example HEAD\n *\n * @note `head` refers to where you are right now; the current reference at a\n * given time.The revision can be a full [hash value (see\n * glossary)](https://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.186-5.pdf),\n * of the recorded change to a ref within a repository pointing to a\n * commit [commit](https://git-scm.com/docs/git-commit) object. It does\n * not necessarily have to be a hash; it can simply define a [revision\n * number](https://svnbook.red-bean.com/en/1.7/svn.tour.revs.specifiers.html)\n * which is an integer that is monotonically increasing. In cases where\n * it is identical to the `ref.head.name`, it **SHOULD** still be included.\n * It is up to the implementer to decide which value to set as the\n * revision based on the VCS system and situational context.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_REF_HEAD_REVISION = 'vcs.ref.head.revision' as const;\n\n/**\n * The type of the [reference](https://git-scm.com/docs/gitglossary#def_ref) in the repository.\n *\n * @example branch\n * @example tag\n *\n * @note `head` refers to where you are right now; the current reference at a\n * given time.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_REF_HEAD_TYPE = 'vcs.ref.head.type' as const;\n\n/**\n * Enum value \"branch\" for attribute {@link ATTR_VCS_REF_HEAD_TYPE}.\n *\n * [branch](https://git-scm.com/docs/gitglossary#Documentation/gitglossary.txt-aiddefbranchabranch)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_REF_HEAD_TYPE_VALUE_BRANCH = \"branch\" as const;\n\n/**\n * Enum value \"tag\" for attribute {@link ATTR_VCS_REF_HEAD_TYPE}.\n *\n * [tag](https://git-scm.com/docs/gitglossary#Documentation/gitglossary.txt-aiddeftagatag)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_REF_HEAD_TYPE_VALUE_TAG = \"tag\" as const;\n\n/**\n * The type of the [reference](https://git-scm.com/docs/gitglossary#def_ref) in the repository.\n *\n * @example branch\n * @example tag\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_REF_TYPE = 'vcs.ref.type' as const;\n\n/**\n * Enum value \"branch\" for attribute {@link ATTR_VCS_REF_TYPE}.\n *\n * [branch](https://git-scm.com/docs/gitglossary#Documentation/gitglossary.txt-aiddefbranchabranch)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_REF_TYPE_VALUE_BRANCH = \"branch\" as const;\n\n/**\n * Enum value \"tag\" for attribute {@link ATTR_VCS_REF_TYPE}.\n *\n * [tag](https://git-scm.com/docs/gitglossary#Documentation/gitglossary.txt-aiddeftagatag)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_REF_TYPE_VALUE_TAG = \"tag\" as const;\n\n/**\n * Deprecated, use `vcs.change.id` instead.\n *\n * @example 123\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `vcs.change.id`.\n */\nexport const ATTR_VCS_REPOSITORY_CHANGE_ID = 'vcs.repository.change.id' as const;\n\n/**\n * Deprecated, use `vcs.change.title` instead.\n *\n * @example Fixes broken thing\n * @example feat: add my new feature\n * @example [chore] update dependency\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `vcs.change.title`.\n */\nexport const ATTR_VCS_REPOSITORY_CHANGE_TITLE = 'vcs.repository.change.title' as const;\n\n/**\n * The human readable name of the repository. It **SHOULD NOT** include any additional identifier like Group/SubGroup in GitLab or organization in GitHub.\n *\n * @example semantic-conventions\n * @example my-cool-repo\n *\n * @note Due to it only being the name, it can clash with forks of the same\n * repository if collecting telemetry across multiple orgs or groups in\n * the same backends.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_REPOSITORY_NAME = 'vcs.repository.name' as const;\n\n/**\n * Deprecated, use `vcs.ref.head.name` instead.\n *\n * @example my-feature-branch\n * @example tag-1-test\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `vcs.ref.head.name`.\n */\nexport const ATTR_VCS_REPOSITORY_REF_NAME = 'vcs.repository.ref.name' as const;\n\n/**\n * Deprecated, use `vcs.ref.head.revision` instead.\n *\n * @example 9d59409acf479dfa0df1aa568182e43e43df8bbe28d60fcf2bc52e30068802cc\n * @example main\n * @example 123\n * @example HEAD\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `vcs.ref.head.revision`.\n */\nexport const ATTR_VCS_REPOSITORY_REF_REVISION = 'vcs.repository.ref.revision' as const;\n\n/**\n * Deprecated, use `vcs.ref.head.type` instead.\n *\n * @example branch\n * @example tag\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n *\n * @deprecated Replaced by `vcs.ref.head.type`.\n */\nexport const ATTR_VCS_REPOSITORY_REF_TYPE = 'vcs.repository.ref.type' as const;\n\n/**\n * Enum value \"branch\" for attribute {@link ATTR_VCS_REPOSITORY_REF_TYPE}.\n *\n * [branch](https://git-scm.com/docs/gitglossary#Documentation/gitglossary.txt-aiddefbranchabranch)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_REPOSITORY_REF_TYPE_VALUE_BRANCH = \"branch\" as const;\n\n/**\n * Enum value \"tag\" for attribute {@link ATTR_VCS_REPOSITORY_REF_TYPE}.\n *\n * [tag](https://git-scm.com/docs/gitglossary#Documentation/gitglossary.txt-aiddeftagatag)\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_REPOSITORY_REF_TYPE_VALUE_TAG = \"tag\" as const;\n\n/**\n * The [canonical URL](https://support.google.com/webmasters/answer/10347851) of the repository providing the complete HTTP(S) address in order to locate and identify the repository through a browser.\n *\n * @example https://github.com/opentelemetry/open-telemetry-collector-contrib\n * @example https://gitlab.com/my-org/my-project/my-projects-project/repo\n *\n * @note In Git Version Control Systems, the canonical URL **SHOULD NOT** include\n * the `.git` extension.\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_REPOSITORY_URL_FULL = 'vcs.repository.url.full' as const;\n\n/**\n * The type of revision comparison.\n *\n * @example ahead\n * @example behind\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_VCS_REVISION_DELTA_DIRECTION = 'vcs.revision_delta.direction' as const;\n\n/**\n * Enum value \"ahead\" for attribute {@link ATTR_VCS_REVISION_DELTA_DIRECTION}.\n *\n * How many revisions the change is ahead of the target ref.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_REVISION_DELTA_DIRECTION_VALUE_AHEAD = \"ahead\" as const;\n\n/**\n * Enum value \"behind\" for attribute {@link ATTR_VCS_REVISION_DELTA_DIRECTION}.\n *\n * How many revisions the change is behind the target ref.\n *\n * @experimental This enum value is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const VCS_REVISION_DELTA_DIRECTION_VALUE_BEHIND = \"behind\" as const;\n\n/**\n * Additional description of the web engine (e.g. detailed version and edition information).\n *\n * @example WildFly Full 21.0.0.Final (WildFly Core 13.0.1.Final) - 2.2.2.Final\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_WEBENGINE_DESCRIPTION = 'webengine.description' as const;\n\n/**\n * The name of the web engine.\n *\n * @example WildFly\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_WEBENGINE_NAME = 'webengine.name' as const;\n\n/**\n * The version of the web engine.\n *\n * @example 21.0.0\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_WEBENGINE_VERSION = 'webengine.version' as const;\n\n/**\n * The System Management Facility (SMF) Identifier uniquely identified a z/OS system within a SYSPLEX or mainframe environment and is used for system and performance analysis.\n *\n * @example SYS1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ZOS_SMF_ID = 'zos.smf.id' as const;\n\n/**\n * The name of the SYSPLEX to which the z/OS system belongs too.\n *\n * @example SYSPLEX1\n *\n * @experimental This attribute is experimental and is subject to breaking changes in minor releases of `@opentelemetry/semantic-conventions`.\n */\nexport const ATTR_ZOS_SYSPLEX_NAME = 'zos.sysplex.name' as const;\n\n"]}
|