UNPKG

@azure/monitor-opentelemetry

Version:
139 lines 5.49 kB
/* * Copyright (c) Microsoft Corporation. * Licensed under the MIT License. * * Code generated by Microsoft (R) AutoRest Code Generator. * Changes may cause incorrect behavior and will be lost if the code is regenerated. */ import * as coreClient from "@azure/core-client"; import * as Parameters from "./models/parameters.js"; import * as Mappers from "./models/mappers.js"; export class QuickpulseClient extends coreClient.ServiceClient { /** * Initializes a new instance of the QuickpulseClient class. * @param options The parameter options */ constructor(options) { var _a, _b; // Initializing default values for options if (!options) { options = {}; } const defaults = { requestContentType: "application/json; charset=utf-8", }; const packageDetails = `azsdk-js-monitor-opentelemetry/1.0.0-beta.0`; const userAgentPrefix = options.userAgentOptions && options.userAgentOptions.userAgentPrefix ? `${options.userAgentOptions.userAgentPrefix} ${packageDetails}` : `${packageDetails}`; const optionsWithDefaults = Object.assign(Object.assign(Object.assign({}, defaults), options), { userAgentOptions: { userAgentPrefix, }, endpoint: (_b = (_a = options.endpoint) !== null && _a !== void 0 ? _a : options.baseUri) !== null && _b !== void 0 ? _b : "{endpoint}" }); super(optionsWithDefaults); // Assigning values to Constant parameters this.apiVersion = options.apiVersion || "2024-04-01-preview"; this.addCustomApiVersionPolicy(options.apiVersion); } /** A function that adds a policy that sets the api-version (or equivalent) to reflect the library version. */ addCustomApiVersionPolicy(apiVersion) { if (!apiVersion) { return; } const apiVersionPolicy = { name: "CustomApiVersionPolicy", async sendRequest(request, next) { const param = request.url.split("?"); if (param.length > 1) { const newParams = param[1].split("&").map((item) => { if (item.indexOf("api-version") > -1) { return "api-version=" + apiVersion; } else { return item; } }); request.url = param[0] + "?" + newParams.join("&"); } return next(request); }, }; this.pipeline.addPolicy(apiVersionPolicy); } /** * Determine whether there is any subscription to the metrics and documents. * @param endpoint The endpoint of the Live Metrics service. * @param ikey The instrumentation key of the target Application Insights component for which the * client checks whether there's any subscription to it. * @param options The options parameters. */ isSubscribed(endpoint, ikey, options) { return this.sendOperationRequest({ endpoint, ikey, options }, isSubscribedOperationSpec); } /** * Publish live metrics to the Live Metrics service when there is an active subscription to the * metrics. * @param endpoint The endpoint of the Live Metrics service. * @param ikey The instrumentation key of the target Application Insights component for which the * client checks whether there's any subscription to it. * @param options The options parameters. */ publish(endpoint, ikey, options) { return this.sendOperationRequest({ endpoint, ikey, options }, publishOperationSpec); } } // Operation Specifications const serializer = coreClient.createSerializer(Mappers, /* isXml */ false); const isSubscribedOperationSpec = { path: "/QuickPulseService.svc/ping", httpMethod: "POST", responses: { 200: { bodyMapper: Mappers.CollectionConfigurationInfo, headersMapper: Mappers.QuickpulseClientIsSubscribedHeaders, }, default: { bodyMapper: Mappers.ServiceError, }, }, requestBody: Parameters.monitoringDataPoint, queryParameters: [Parameters.apiVersion, Parameters.ikey], urlParameters: [Parameters.endpoint], headerParameters: [ Parameters.contentType, Parameters.accept, Parameters.transmissionTime, Parameters.machineName, Parameters.instanceName, Parameters.streamId, Parameters.roleName, Parameters.invariantVersion, Parameters.configurationEtag, ], mediaType: "json", serializer, }; const publishOperationSpec = { path: "/QuickPulseService.svc/post", httpMethod: "POST", responses: { 200: { bodyMapper: Mappers.CollectionConfigurationInfo, headersMapper: Mappers.QuickpulseClientPublishHeaders, }, default: { bodyMapper: Mappers.ServiceError, }, }, requestBody: Parameters.monitoringDataPoints, queryParameters: [Parameters.apiVersion, Parameters.ikey], urlParameters: [Parameters.endpoint], headerParameters: [ Parameters.contentType, Parameters.accept, Parameters.transmissionTime, Parameters.configurationEtag, ], mediaType: "json", serializer, }; //# sourceMappingURL=quickpulseClient.js.map