UNPKG

@atomist/sdm

Version:

Atomist Software Delivery Machine SDK

91 lines 5 kB
"use strict"; /* * Copyright © 2020 Atomist, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); 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; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.RespondOnGoalCompletion = void 0; const decorators_1 = require("@atomist/automation-client/lib/decorators"); const globals_1 = require("@atomist/automation-client/lib/globals"); const graphQL_1 = require("@atomist/automation-client/lib/graph/graphQL"); const HandlerResult_1 = require("@atomist/automation-client/lib/HandlerResult"); const logger_1 = require("@atomist/automation-client/lib/util/logger"); const stringify = require("json-stringify-safe"); const fetchGoalsOnCommit_1 = require("../../../../../api-helper/goal/fetchGoalsOnCommit"); const handlerRegistrations_1 = require("../../../../../api-helper/machine/handlerRegistrations"); const addressChannels_1 = require("../../../../../api/context/addressChannels"); const skillContext_1 = require("../../../../../api/context/skillContext"); const validateGoal_1 = require("../../../../delivery/goals/support/validateGoal"); const goalSigning_1 = require("../../../../signing/goalSigning"); /** * Respond to a failure or success status by running listeners */ let RespondOnGoalCompletion = class RespondOnGoalCompletion { constructor(repoRefResolver, credentialsFactory, goalCompletionListeners, preferenceStoreFactory) { this.repoRefResolver = repoRefResolver; this.credentialsFactory = credentialsFactory; this.goalCompletionListeners = goalCompletionListeners; this.preferenceStoreFactory = preferenceStoreFactory; } async handle(event, context) { let sdmGoal = event.data.SdmGoal[0]; if (!validateGoal_1.shouldHandle(sdmGoal)) { logger_1.logger.debug(`Goal ${sdmGoal.uniqueName} skipped because not managed by this SDM`); return HandlerResult_1.Success; } sdmGoal = await goalSigning_1.verifyGoal(sdmGoal, this.configuration.sdm.goalSigning, context); const id = this.repoRefResolver.repoRefFromPush(sdmGoal.push); const goals = fetchGoalsOnCommit_1.fetchGoalsFromPush(sdmGoal); const gsi = { id, context, credentials: await handlerRegistrations_1.resolveCredentialsPromise(this.credentialsFactory.eventHandlerCredentials(context, id)), addressChannels: addressChannels_1.addressChannelsFor(sdmGoal.push.repo, context), configuration: this.configuration, preferences: this.preferenceStoreFactory(context), allGoals: goals, completedGoal: sdmGoal, skill: skillContext_1.createSkillContext(context), }; try { await Promise.all(this.goalCompletionListeners.map(l => l(gsi))); } catch (e) { logger_1.logger.warn(`Error occurred while running goal completion listener: ${stringify(e)}`); } return HandlerResult_1.Success; } }; __decorate([ decorators_1.Value(""), __metadata("design:type", Object) ], RespondOnGoalCompletion.prototype, "configuration", void 0); RespondOnGoalCompletion = __decorate([ decorators_1.EventHandler("Run a listener on goal failure or success", () => graphQL_1.subscription({ name: "OnAnyCompletedSdmGoal", variables: { registration: () => { var _a, _b; return [(_b = (_a = globals_1.automationClientInstance()) === null || _a === void 0 ? void 0 : _a.configuration) === null || _b === void 0 ? void 0 : _b.name]; } }, })), __metadata("design:paramtypes", [Object, Object, Array, Function]) ], RespondOnGoalCompletion); exports.RespondOnGoalCompletion = RespondOnGoalCompletion; //# sourceMappingURL=RespondOnGoalCompletion.js.map