UNPKG

2.62 kBJavaScriptView Raw
1"use strict";
2/*
3 * Copyright © 2019 Atomist, Inc.
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
18 return new (P || (P = Promise))(function (resolve, reject) {
19 function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
20 function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
21 function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
22 step((generator = generator.apply(thisArg, _arguments || [])).next());
23 });
24};
25Object.defineProperty(exports, "__esModule", { value: true });
26const automation_client_1 = require("@atomist/automation-client");
27const cluster = require("cluster");
28const _ = require("lodash");
29/**
30 * Automation listener that reports goal round trip metrics to StatsD.
31 */
32class SdmGoalMetricReportingAutomationEventListener extends automation_client_1.AutomationEventListenerSupport {
33 startupSuccessful(client) {
34 return __awaiter(this, void 0, void 0, function* () {
35 if (cluster.isMaster && client.configuration.statsd.enabled) {
36 this.statsd = client.configuration.statsd.__instance;
37 }
38 });
39 }
40 eventIncoming(payload) {
41 if (cluster.isMaster && !!this.statsd && process.env.ATOMIST_ISOLATED_GOAL !== "forked") {
42 const ts = _.get(payload.data, "SdmGoal[0].ts");
43 const name = _.get(payload.data, "SdmGoal[0].name");
44 if (!!name) {
45 this.statsd.increment(`counter.goal`, 1, [`atomist_goal:${name}`], () => {
46 });
47 }
48 if (ts) {
49 this.statsd.timing("timer.goal.round_trip", Date.now() - ts, 1, {}, () => {
50 });
51 }
52 }
53 }
54}
55exports.SdmGoalMetricReportingAutomationEventListener = SdmGoalMetricReportingAutomationEventListener;
56//# sourceMappingURL=SdmGoalMetricReportingAutomationEventListener.js.map
\No newline at end of file