Example #1
0
        public void ExecuteTask()
        {
            if (IsExcluded())
            {
                Log.LogMessage("Project {0} excluded from task", HubProjectName);
            }
            else
            {
                // Creates output directory if it doesn't already exist
                Directory.CreateDirectory(OutputDirectory);

                // Define output files
                string bdioFilePath     = $"{OutputDirectory}/{HubProjectName}.jsonld";
                string flatListFilePath = $"{OutputDirectory}/{HubProjectName}_flat.txt";

                // Execute task functionality
                if (CreateFlatDependencyList)
                {
                    string[] externalIds = CreateFlatList().ToArray();
                    File.WriteAllLines(flatListFilePath, externalIds, Encoding.UTF8);
                }

                if (CreateHubBdio)
                {
                    BdioContent bdioContent = BuildBOM();
                    File.WriteAllText(bdioFilePath, bdioContent.ToString());
                }

                if (DeployHubBdio)
                {
                    string      bdio        = File.ReadAllText(bdioFilePath);
                    BdioContent bdioContent = BdioContent.Parse(bdio);
                    DeployBdioDataService.Deploy(bdioContent);
                }

                // Only wait for scan if we have to
                if (DeployHubBdio && (CheckPolicies || CreateHubBdio || WaitForDeployment))
                {
                    WaitForHub();
                }

                if (CreateHubReport)
                {
                    ProjectView        projectView        = ProjectDataService.GetProjectView(HubProjectName);
                    ProjectVersionView projectVersionView = ProjectDataService.GetMostRecentVersion(projectView);
                    ReportData         reportData         = RiskReportDataService.GetReportData(projectView, projectVersionView);
                    RiskReportDataService.WriteToRiskReport(reportData, OutputDirectory);
                }

                if (CheckPolicies)
                {
                    PolicyStatus policyStatus = new PolicyStatus(GetPolicies());
                    LogPolicyViolations(policyStatus);
                }
            }
        }
Example #2
0
        private List <ScanSummaryView> GetPendingScans(String projectName, String projectVersion)
        {
            List <ScanSummaryView> pendingScans = new List <ScanSummaryView>();

            try
            {
                ProjectView        projectItem        = projectDataService.GetProjectView(projectName);
                ProjectVersionView projectVersionItem = projectVersionDataService.GetProjectVersion(projectItem, projectVersion);
                string             projectVersionUrl  = projectVersionItem.Metadata.Href;

                List <CodeLocationView> allCodeLocations      = codeLocationDataService.GetAllCodeLocationsForCodeLocationType(CodeLocationTypeEnum.BOM_IMPORT);
                List <string>           allScanSummariesLinks = new List <string>();
                foreach (CodeLocationView codeLocationItem in allCodeLocations)
                {
                    string mappedProjectVersionUrl = codeLocationItem.MappedProjectVersion;
                    if (projectVersionUrl.Equals(mappedProjectVersionUrl))
                    {
                        string scanSummariesLink = MetadataResponseService.GetLink(codeLocationItem, ApiLinks.SCANS_LINK);
                        allScanSummariesLinks.Add(scanSummariesLink);
                    }
                }

                List <ScanSummaryView> allScanSummaries = new List <ScanSummaryView>();
                foreach (string scanSummaryLink in allScanSummariesLinks)
                {
                    allScanSummaries.AddRange(scanSummaryDataService.GetAllItems <ScanSummaryView>(scanSummaryLink));
                }

                pendingScans = new List <ScanSummaryView>();
                foreach (ScanSummaryView scanSummaryItem in allScanSummaries)
                {
                    if (IsPending(scanSummaryItem.Status))
                    {
                        pendingScans.Add(scanSummaryItem);
                    }
                }
            }
            catch (Exception ex)
            {
                pendingScans = new List <ScanSummaryView>();
                // ignore, since we might not have found a project or version, etc
                // so just keep waiting until the timeout
            }

            return(pendingScans);
        }