UNPKG

3.18 kBJavaScriptView Raw
1"use strict";
2/*
3 * Copyright © 2018 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 EphemeralProgressLog_1 = require("@atomist/sdm/api-helper/log/EphemeralProgressLog");
28const firstAvailableProgressLog_1 = require("@atomist/sdm/api-helper/log/firstAvailableProgressLog");
29const LoggingProgressLog_1 = require("@atomist/sdm/api-helper/log/LoggingProgressLog");
30const WriteToAllProgressLog_1 = require("@atomist/sdm/api-helper/log/WriteToAllProgressLog");
31const DashboardDisplayProgressLog_1 = require("./DashboardDisplayProgressLog");
32/**
33 * Create a progress log that will use Rolar logging service if available,
34 * otherwise falling back to logging.
35 * @param {string} rolarBaseUrl
36 * @param {string} dashboardBaseUrl
37 * @return {ProgressLogFactory}
38 */
39function rolarAndDashboardLogFactory(rolarBaseUrl, bufferSize = 1000, flushInterval = 2000) {
40 let persistentLogFactory = (context, sdmGoal, fallback) => firstAvailableProgressLog_1.firstAvailableProgressLog(fallback);
41 if (rolarBaseUrl) {
42 automation_client_1.logger.info("Logging with Rolar: " + rolarBaseUrl);
43 persistentLogFactory = (context, sdmGoal, fallback) => {
44 return firstAvailableProgressLog_1.firstAvailableProgressLog(new DashboardDisplayProgressLog_1.DashboardDisplayProgressLog(rolarBaseUrl, bufferSize, flushInterval, context, sdmGoal), fallback);
45 };
46 }
47 return (context, sdmGoal) => __awaiter(this, void 0, void 0, function* () {
48 const name = sdmGoal.name;
49 const persistentLog = yield persistentLogFactory(context, sdmGoal, new LoggingProgressLog_1.LoggingProgressLog(name, "info"));
50 return new WriteToAllProgressLog_1.WriteToAllProgressLog(name, yield EphemeralProgressLog_1.createEphemeralProgressLog(context, sdmGoal), persistentLog);
51 });
52}
53exports.rolarAndDashboardLogFactory = rolarAndDashboardLogFactory;
54//# sourceMappingURL=rolarAndDashboardLogFactory.js.map
\No newline at end of file