@atomist/sdm-pack-aspect
Version:
an Atomist SDM Extension Pack for visualizing drift across an organization
78 lines (70 loc) • 3.13 kB
text/typescript
/*
* 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 { logger } from "@atomist/automation-client";
import {
PublishFingerprints,
PublishFingerprintsFor,
RepoIdentification,
} from "@atomist/sdm-pack-fingerprint";
import { ProjectAnalysisResultStore } from "../../analysis/offline/persist/ProjectAnalysisResultStore";
import { computeAnalyticsForFingerprintKind } from "../../analysis/offline/spider/analytics";
import { ProjectAnalysisResult } from "../../analysis/ProjectAnalysisResult";
import { Analyzed } from "../AspectRegistry";
/**
* "Publish" fingerprints to local store
* @param {ProjectAnalysisResultStore} store
* @return {PublishFingerprints}
*/
export function storeFingerprintsFor(store: ProjectAnalysisResultStore): PublishFingerprintsFor {
return async (ctx, aspects, repoIdentification, fingerprints, previous) => {
if (fingerprints.length === 0) {
return true;
}
const analysis: Analyzed = {
id: repoIdentification as any,
fingerprints,
};
const paResult: ProjectAnalysisResult = {
repoRef: repoIdentification as any,
workspaceId: ctx.context.workspaceId,
timestamp: undefined,
analysis,
};
logger.info("Routing %d fingerprints to local database for workspace %s",
fingerprints.length, ctx.context.workspaceId);
const found = await store.loadByRepoRef(paResult.analysis.id, false);
if (!!found) {
const results = await store.persistAdditionalFingerprints(paResult.analysis);
logger.info("Persisting additional fingerprint results for %s: %j", paResult.analysis.id.url, results);
for (const fp of fingerprints) {
await computeAnalyticsForFingerprintKind(store, ctx.context.workspaceId, fp.type, fp.name);
}
return results.failures.length === 0;
} else {
const results = await store.persist(paResult);
logger.info("Persisting snapshot for %s: %j", paResult.analysis.id.url, results);
for (const fp of fingerprints) {
await computeAnalyticsForFingerprintKind(store, ctx.context.workspaceId, fp.type, fp.name);
}
return results.failed.length === 0;
}
};
}
export function storeFingerprints(store: ProjectAnalysisResultStore): PublishFingerprints {
return (i, aspects, fps, previous) => {
return storeFingerprintsFor(store)(i, aspects, i.id as RepoIdentification, fps, previous);
};
}