UNPKG

@atomist/sdm-core

Version:

Atomist Software Delivery Machine - Implementation

99 lines (87 loc) 3.67 kB
/* * Copyright © 2019 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. */ import { Configuration, EventFired, GraphQL, HandlerContext, HandlerResult, Success, Value, } from "@atomist/automation-client"; import { EventHandler } from "@atomist/automation-client/lib/decorators"; import { HandleEvent } from "@atomist/automation-client/lib/HandleEvent"; import { addressChannelsFor, CredentialsResolver, FingerprintDifference, FingerprintDifferenceListener, FingerprintDifferenceListenerInvocation, FingerprintValue, PreferenceStoreFactory, RepoRefResolver, resolveCredentialsPromise, } from "@atomist/sdm"; import * as _ from "lodash"; import * as schema from "../../../../typings/types"; /** * React to a PushImpact event to react to semantic diffs */ @EventHandler("Find semantic diffs from a PushImpact", GraphQL.subscription("OnPushImpact")) export class ReactToSemanticDiffsOnPushImpact implements HandleEvent<schema.OnPushImpact.Subscription> { @Value("") public configuration: Configuration; constructor(private readonly differenceListeners: FingerprintDifferenceListener[], private readonly repoRefResolver: RepoRefResolver, private readonly credentialsFactory: CredentialsResolver, private readonly preferencesStoreFactory: PreferenceStoreFactory) { } public async handle(event: EventFired<schema.OnPushImpact.Subscription>, context: HandlerContext): Promise<HandlerResult> { const pushImpact = event.data.PushImpact[0]; const after = pushImpact.push.after; const id = this.repoRefResolver.toRemoteRepoRef(after.repo, { sha: after.sha }); const oldFingerprints = pushImpact.push.before.fingerprints; const newFingerprints = after.fingerprints; const oldValues: FingerprintValue[] = oldFingerprints .filter(f => !!f.name) as FingerprintValue[]; const newValues: FingerprintValue[] = newFingerprints .filter(f => !!f.name) as FingerprintValue[]; const allNames = _.uniq(oldValues.map(f => f.name) .concat(newValues.map(f => f.name))); const diffs: FingerprintDifference[] = allNames .map(name => ({ oldValue: oldValues.find(f => f.name === name), newValue: newValues.find(f => f.name === name), })) .filter(fv => _.get(fv, "oldValue.sha") !== _.get(fv, "newValue.sha")); const credentials = await resolveCredentialsPromise(this.credentialsFactory.eventHandlerCredentials(context, id)); const preferences = this.preferencesStoreFactory(context); const inv: FingerprintDifferenceListenerInvocation = { id, context, credentials, addressChannels: addressChannelsFor(after.repo, context), configuration: this.configuration, preferences, diffs, }; await Promise.all(this.differenceListeners.map(dh => dh(inv))); return Success; } }