From d8831d57bca0313ca2b0e19949be1171d5c7b926 Mon Sep 17 00:00:00 2001 From: Chidozie Ononiwu Date: Fri, 24 Feb 2023 11:37:09 -0800 Subject: [PATCH] Add API to get status of package name approval --- .../Controllers/AutoReviewController.cs | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/src/dotnet/APIView/APIViewWeb/Controllers/AutoReviewController.cs b/src/dotnet/APIView/APIViewWeb/Controllers/AutoReviewController.cs index a53176e7e89c..dd818446046d 100644 --- a/src/dotnet/APIView/APIViewWeb/Controllers/AutoReviewController.cs +++ b/src/dotnet/APIView/APIViewWeb/Controllers/AutoReviewController.cs @@ -3,6 +3,7 @@ using APIViewWeb.Filters; using APIViewWeb.Managers; +using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Logging; @@ -44,21 +45,23 @@ public async Task UploadAutoReview([FromForm] IFormFile file, stri } // Return internal server error for any unknown error return StatusCode(statusCode: StatusCodes.Status500InternalServerError); - } + } [HttpGet] - public async Task GetReviewStatus(string language, string packageName, string reviewId = null) + public async Task GetReviewStatus(string language, string packageName, string reviewId = null, bool? firstReleaseStatusOnly = null) { // This API is used by prepare release script to check if API review for a package is approved or not. // This caller script doesn't have artifact to submit and so it can't check using create review API // So it rely on approval status of latest revision of automatic review for the package // With new restriction of creating automatic review only from master branch or GA version, this should ensure latest revision - // is infact the version intended to be released. + // is infact the version intended to be released. + + ReviewType filtertype = (firstReleaseStatusOnly == true) ? ReviewType.All : ReviewType.Automatic; ReviewModel review; if (String.IsNullOrEmpty(reviewId)) { - IEnumerable reviews = await _reviewManager.GetReviewsAsync(false, language, packageName: packageName, ReviewType.Automatic); + IEnumerable reviews = await _reviewManager.GetReviewsAsync(false, language, packageName: packageName, filtertype); review = reviews.FirstOrDefault(); } else @@ -68,9 +71,10 @@ public async Task GetReviewStatus(string language, string packageN if (review != null) { - _logger.LogInformation("Found review ID " + review.ReviewId + " for package " + packageName); + _logger.LogInformation("Found review ID " + review.ReviewId + " for package " + packageName); + // Return 200 OK for approved review and 201 for review in pending status - if (review.Revisions.LastOrDefault().IsApproved) + if (firstReleaseStatusOnly != true && review.Revisions.LastOrDefault().IsApproved) { return Ok(); }