Make the Quay UI work for Clair 1.0
This commit is contained in:
		
							parent
							
								
									4bd5996bbf
								
							
						
					
					
						commit
						6a37f93718
					
				
					 3 changed files with 106 additions and 77 deletions
				
			
		|  | @ -156,41 +156,48 @@ angular.module('quay').directive('repoPanelTags', function () { | |||
|         var params = { | ||||
|           'imageid': image_id, | ||||
|           'repository': $scope.repository.namespace + '/' + $scope.repository.name, | ||||
|           'vulnerabilities': true, | ||||
|         }; | ||||
| 
 | ||||
|         ApiService.getRepoImageVulnerabilities(null, params).then(function(resp) { | ||||
|         ApiService.getRepoImageSecurity(null, params).then(function(resp) { | ||||
|           imageData.loading = false; | ||||
|           imageData.status = resp['status']; | ||||
| 
 | ||||
|           if (imageData.status == 'scanned') { | ||||
|             var vulnerabilities = resp.data.Vulnerabilities; | ||||
| 
 | ||||
|             imageData.hasVulnerabilities = !!vulnerabilities.length; | ||||
|             imageData.vulnerabilities = vulnerabilities; | ||||
| 
 | ||||
|             var vulnerabilities = []; | ||||
|             var highest = { | ||||
|               'Priority': 'Unknown', | ||||
|               'Severity': 'Unknown', | ||||
|               'Count': 0, | ||||
|               'index': 100000 | ||||
|             }; | ||||
| 
 | ||||
|             resp.data.Vulnerabilities.forEach(function(v) { | ||||
|               if (VulnerabilityService.LEVELS[v.Priority].index == 0) { | ||||
|                 $scope.defcon1[v.ID] = v; | ||||
|                 $scope.hasDefcon1 = true; | ||||
|               } | ||||
|             if (resp.data && resp.data.Layer && resp.data.Layer.Features) { | ||||
|               resp.data.Layer.Features.forEach(function(feature) { | ||||
|                 if (feature.Vulnerabilities) { | ||||
|                   feature.Vulnerabilities.forEach(function(vuln) { | ||||
|                     if (VulnerabilityService.LEVELS[vuln.Severity].index == 0) { | ||||
|                       $scope.defcon1[vuln.ID] = v; | ||||
|                       $scope.hasDefcon1 = true; | ||||
|                     } | ||||
| 
 | ||||
|               if (VulnerabilityService.LEVELS[v.Priority].index < highest.index) { | ||||
|                 highest = { | ||||
|                   'Priority': v.Priority, | ||||
|                   'Count': 1, | ||||
|                   'index': VulnerabilityService.LEVELS[v.Priority].index | ||||
|                     if (VulnerabilityService.LEVELS[vuln.Severity].index < highest.index) { | ||||
|                       highest = { | ||||
|                         'Priority': vuln.Severity, | ||||
|                         'Count': 1, | ||||
|                         'index': VulnerabilityService.LEVELS[vuln.Severity].index | ||||
|                       } | ||||
|                     } else if (VulnerabilityService.LEVELS[vuln.Severity].index == highest.index) { | ||||
|                       highest['Count']++; | ||||
|                     } | ||||
| 
 | ||||
|                     vulnerabilities.push(vuln); | ||||
|                   }); | ||||
|                 } | ||||
|               } else if (VulnerabilityService.LEVELS[v.Priority].index == highest.index) { | ||||
|                 highest['Count']++; | ||||
|               } | ||||
|             }); | ||||
|               }); | ||||
|             } | ||||
| 
 | ||||
|             imageData.hasVulnerabilities = !!vulnerabilities.length; | ||||
|             imageData.vulnerabilities = vulnerabilities; | ||||
|             imageData.highestVulnerability = highest; | ||||
|           } | ||||
|         }, function() { | ||||
|  | @ -355,4 +362,3 @@ angular.module('quay').directive('repoPanelTags', function () { | |||
|   }; | ||||
|   return directiveDefinitionObject; | ||||
| }); | ||||
| 
 | ||||
|  |  | |||
		Reference in a new issue