Merge pull request #10980 from AllForNothing/scan-bug

Fix  a bug for scanning
This commit is contained in:
Will Sun 2020-03-10 09:51:10 +08:00 committed by GitHub
commit cb370f8dd9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 30 additions and 13 deletions

View File

@ -1,4 +1,4 @@
import { Component, Input, OnInit, ViewChild } from '@angular/core'; import { Component, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';
import { AdditionsService } from "../additions.service"; import { AdditionsService } from "../additions.service";
import { ClrDatagridComparatorInterface, ClrLoadingState } from "@clr/angular"; import { ClrDatagridComparatorInterface, ClrLoadingState } from "@clr/angular";
import { finalize } from "rxjs/operators"; import { finalize } from "rxjs/operators";
@ -18,13 +18,14 @@ import {
} from "../../../../../../lib/utils/utils"; } from "../../../../../../lib/utils/utils";
import { ChannelService } from "../../../../../../lib/services/channel.service"; import { ChannelService } from "../../../../../../lib/services/channel.service";
import { ResultBarChartComponent } from "../../../vulnerability-scanning/result-bar-chart.component"; import { ResultBarChartComponent } from "../../../vulnerability-scanning/result-bar-chart.component";
import { Subscription } from "rxjs";
@Component({ @Component({
selector: 'hbr-artifact-vulnerabilities', selector: 'hbr-artifact-vulnerabilities',
templateUrl: './artifact-vulnerabilities.component.html', templateUrl: './artifact-vulnerabilities.component.html',
styleUrls: ['./artifact-vulnerabilities.component.scss'] styleUrls: ['./artifact-vulnerabilities.component.scss']
}) })
export class ArtifactVulnerabilitiesComponent implements OnInit { export class ArtifactVulnerabilitiesComponent implements OnInit, OnDestroy {
@Input() @Input()
vulnerabilitiesLink: AdditionLink; vulnerabilitiesLink: AdditionLink;
@Input() @Input()
@ -48,6 +49,7 @@ export class ArtifactVulnerabilitiesComponent implements OnInit {
hasShowLoading: boolean = false; hasShowLoading: boolean = false;
@ViewChild(ResultBarChartComponent, {static: false}) @ViewChild(ResultBarChartComponent, {static: false})
resultBarChartComponent: ResultBarChartComponent; resultBarChartComponent: ResultBarChartComponent;
sub: Subscription;
constructor( constructor(
private errorHandler: ErrorHandler, private errorHandler: ErrorHandler,
private additionsService: AdditionsService, private additionsService: AdditionsService,
@ -67,10 +69,18 @@ export class ArtifactVulnerabilitiesComponent implements OnInit {
this.getVulnerabilities(); this.getVulnerabilities();
this.getScanningPermission(); this.getScanningPermission();
this.getProjectScanner(); this.getProjectScanner();
this.channel.ArtifactDetail$.subscribe(tag => { if (!this.sub) {
this.sub = this.channel.ArtifactDetail$.subscribe(tag => {
this.getVulnerabilities(); this.getVulnerabilities();
}); });
} }
}
ngOnDestroy() {
if (this.sub) {
this.sub.unsubscribe();
this.sub = null;
}
}
getVulnerabilities() { getVulnerabilities() {
if (this.vulnerabilitiesLink if (this.vulnerabilitiesLink

View File

@ -147,8 +147,6 @@ export class ResultBarChartComponent implements OnInit, OnDestroy {
if (!this.repoName || !this.artifactDigest) { if (!this.repoName || !this.artifactDigest) {
return; return;
} }
// this.tagService.getTag(this.repoName, this.artifactId)
this.artifactService.getArtifact({ this.artifactService.getArtifact({
projectName: this.projectName, projectName: this.projectName,
repositoryName: this.repoName, repositoryName: this.repoName,

View File

@ -1,5 +1,5 @@
import { Component, OnInit, Input } from '@angular/core'; import { Component, OnInit, Input, OnDestroy } from '@angular/core';
import { forkJoin } from "rxjs"; import { forkJoin, Subscription } from "rxjs";
import { finalize } from "rxjs/operators"; import { finalize } from "rxjs/operators";
import { ClrDatagridComparatorInterface, ClrLoadingState } from "@clr/angular"; import { ClrDatagridComparatorInterface, ClrLoadingState } from "@clr/angular";
import { import {
@ -17,7 +17,7 @@ import { DEFAULT_SUPPORTED_MIME_TYPE, SEVERITY_LEVEL_MAP, VULNERABILITY_SEVERITY
templateUrl: './result-grid.component.html', templateUrl: './result-grid.component.html',
styleUrls: ['./scanning.scss'] styleUrls: ['./scanning.scss']
}) })
export class ResultGridComponent implements OnInit { export class ResultGridComponent implements OnInit, OnDestroy {
scanningResults: VulnerabilityItem[] = []; scanningResults: VulnerabilityItem[] = [];
dataCache: VulnerabilityItem[] = []; dataCache: VulnerabilityItem[] = [];
loading: boolean = false; loading: boolean = false;
@ -29,6 +29,7 @@ export class ResultGridComponent implements OnInit {
hasEnabledScanner: boolean = false; hasEnabledScanner: boolean = false;
scanBtnState: ClrLoadingState = ClrLoadingState.DEFAULT; scanBtnState: ClrLoadingState = ClrLoadingState.DEFAULT;
severitySort: ClrDatagridComparatorInterface<VulnerabilityItem>; severitySort: ClrDatagridComparatorInterface<VulnerabilityItem>;
sub: Subscription;
constructor( constructor(
private scanningService: ScanningResultService, private scanningService: ScanningResultService,
private channel: ChannelService, private channel: ChannelService,
@ -46,10 +47,18 @@ export class ResultGridComponent implements OnInit {
ngOnInit(): void { ngOnInit(): void {
this.loadResults(this.repositoryId, this.tagId); this.loadResults(this.repositoryId, this.tagId);
this.getScanPermissions(this.projectId); this.getScanPermissions(this.projectId);
if (!this.sub) {
this.channel.ArtifactDetail$.subscribe(tag => { this.channel.ArtifactDetail$.subscribe(tag => {
this.loadResults(this.repositoryId, this.tagId); this.loadResults(this.repositoryId, this.tagId);
}); });
} }
}
ngOnDestroy() {
if (this.sub) {
this.sub.unsubscribe();
this.sub = null;
}
}
getLevel(v: VulnerabilityItem): number { getLevel(v: VulnerabilityItem): number {
if (v && v.severity && SEVERITY_LEVEL_MAP[v.severity]) { if (v && v.severity && SEVERITY_LEVEL_MAP[v.severity]) {
return SEVERITY_LEVEL_MAP[v.severity]; return SEVERITY_LEVEL_MAP[v.severity];