Skip to content

Commit

Permalink
PIN-4487 BKE - Catalog-Process - Endpoint /eservices/{eServiceId}/des…
Browse files Browse the repository at this point in the history
…criptors/{descriptorId}/documents/{documentId} - Applied restrictions to EService
  • Loading branch information
nttdata-rtorsoli committed Feb 2, 2024
1 parent a0d2469 commit 48448ec
Show file tree
Hide file tree
Showing 6 changed files with 131 additions and 21 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -403,11 +403,21 @@ final case class ProcessApiServiceImpl(
logger.info(operationLabel)

val result: Future[EServiceDoc] = for {
eServiceUuid <- eServiceId.toFutureUUID
descriptorUuid <- descriptorId.toFutureUUID
documentIdUuid <- documentId.toFutureUUID
eServiceDoc <- catalogManagementService.getEServiceDocument(eServiceUuid, descriptorUuid, documentIdUuid)
} yield eServiceDoc.toApi
organizationId <- getOrganizationIdFutureUUID(contexts)
eServiceUuid <- eServiceId.toFutureUUID
descriptorUuid <- descriptorId.toFutureUUID
documentIdUuid <- documentId.toFutureUUID
role <- getUserRolesFuture(contexts)
(catalogItem, catalogDocument) <- catalogManagementService.getEServiceDocument(
eServiceUuid,
descriptorUuid,
documentIdUuid
)
eService <- applyVisibilityToEService(catalogItem, organizationId, role)
_ <-
if (eService.descriptors.map(_.id).contains(descriptorUuid)) Future.successful(())
else Future.failed(DescriptorDocumentNotFound(eServiceId, descriptorId, documentId))
} yield catalogDocument.toApi

onComplete(result) {
getEServiceDocumentByIdResponse[EServiceDoc](operationLabel)(getEServiceDocumentById200)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -237,6 +237,7 @@ object ResponseHandlers extends AkkaResponses {
)(result: Try[T])(implicit contexts: Seq[(String, String)], logger: LoggerTakingImplicit[ContextFieldsToLog]): Route =
result match {
case Success(s) => success(s)
case Failure(ex: EServiceNotFound) => notFound(ex, logMessage)
case Failure(ex: DescriptorDocumentNotFound) => notFound(ex, logMessage)
case Failure(ex: ContentTypeParsingError) => badRequest(ex, logMessage)
case Failure(ex) => internalServerError(ex, logMessage)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ trait CatalogManagementService {
def getEServiceDocument(eServiceId: UUID, descriptorId: UUID, documentId: UUID)(implicit
ec: ExecutionContext,
readModel: ReadModelService
): Future[CatalogDocument]
): Future[(CatalogItem, CatalogDocument)]
def updateEServiceDocument(
eServiceId: String,
descriptorId: String,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -244,14 +244,14 @@ final case class CatalogManagementServiceImpl(invoker: CatalogManagementInvoker,
override def getEServiceDocument(eServiceId: UUID, descriptorId: UUID, documentId: UUID)(implicit
ec: ExecutionContext,
readModel: ReadModelService
): Future[CatalogDocument] = for {
): Future[(CatalogItem, CatalogDocument)] = for {
catalogItem <- ReadModelCatalogQueries
.getEServiceDocument(eServiceId, descriptorId, documentId)
.flatMap(_.toFuture(DescriptorDocumentNotFound(eServiceId.toString, descriptorId.toString, documentId.toString)))
catalogDocument <- getDocument(catalogItem, descriptorId, documentId).toFuture(
DescriptorDocumentNotFound(eServiceId.toString, descriptorId.toString, documentId.toString)
)
} yield catalogDocument
} yield (catalogItem, catalogDocument)

override def getConsumers(eServiceId: UUID, offset: Int, limit: Int)(implicit
ec: ExecutionContext,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2769,26 +2769,27 @@ class CatalogProcessSpec extends SpecHelper with AnyWordSpecLike with ScalatestR
}
}
"Document retrieve" should {
"succeed" in {
"succeed if role is admin and the requester is the producer" in {

val requesterId = UUID.randomUUID()
val descriptorId = UUID.randomUUID()
val documentId = UUID.randomUUID()

implicit val context: Seq[(String, String)] =
Seq("bearer" -> bearerToken, USER_ROLES -> "admin", ORGANIZATION_ID_CLAIM -> UUID.randomUUID().toString)
Seq("bearer" -> bearerToken, USER_ROLES -> "admin", ORGANIZATION_ID_CLAIM -> requesterId.toString)

val descriptor = SpecData.catalogDescriptor.copy(
id = descriptorId,
interface = Some(SpecData.catalogDocument.copy(id = documentId))
)

val eService = SpecData.catalogItem.copy(descriptors = Seq(descriptor))
val eService = SpecData.catalogItem.copy(producerId = requesterId, descriptors = Seq(descriptor))

(mockCatalogManagementService
.getEServiceDocument(_: UUID, _: UUID, _: UUID)(_: ExecutionContext, _: ReadModelService))
.expects(SpecData.catalogItem.id, descriptorId, documentId, *, *)
.once()
.returns(Future.successful(SpecData.catalogDocument.copy(id = documentId)))
.returns(Future.successful((eService, SpecData.catalogDocument.copy(id = documentId))))

Post() ~> service.getEServiceDocumentById(
eService.id.toString,
Expand All @@ -2798,6 +2799,67 @@ class CatalogProcessSpec extends SpecHelper with AnyWordSpecLike with ScalatestR
status shouldEqual StatusCodes.OK
}
}
"succeed if role is api and the requester is the producer" in {

val requesterId = UUID.randomUUID()
val descriptorId = UUID.randomUUID()
val documentId = UUID.randomUUID()

implicit val context: Seq[(String, String)] =
Seq("bearer" -> bearerToken, USER_ROLES -> "api", ORGANIZATION_ID_CLAIM -> requesterId.toString)

val descriptor = SpecData.catalogDescriptor.copy(
id = descriptorId,
interface = Some(SpecData.catalogDocument.copy(id = documentId))
)

val eService = SpecData.catalogItem.copy(producerId = requesterId, descriptors = Seq(descriptor))

(mockCatalogManagementService
.getEServiceDocument(_: UUID, _: UUID, _: UUID)(_: ExecutionContext, _: ReadModelService))
.expects(SpecData.catalogItem.id, descriptorId, documentId, *, *)
.once()
.returns(Future.successful((eService, SpecData.catalogDocument.copy(id = documentId))))

Post() ~> service.getEServiceDocumentById(
eService.id.toString,
descriptorId.toString,
documentId.toString
) ~> check {
status shouldEqual StatusCodes.OK
}
}
"fail if the requester is not the producer and document belongs to a draft descriptor " in {

val requesterId = UUID.randomUUID()
val descriptorId = UUID.randomUUID()
val documentId = UUID.randomUUID()

implicit val context: Seq[(String, String)] =
Seq("bearer" -> bearerToken, USER_ROLES -> "admin", ORGANIZATION_ID_CLAIM -> UUID.randomUUID().toString)

val descriptor = SpecData.catalogDescriptor.copy(
id = descriptorId,
state = Draft,
interface = Some(SpecData.catalogDocument.copy(id = documentId))
)

val eService = SpecData.catalogItem.copy(producerId = requesterId, descriptors = Seq(descriptor))

(mockCatalogManagementService
.getEServiceDocument(_: UUID, _: UUID, _: UUID)(_: ExecutionContext, _: ReadModelService))
.expects(SpecData.catalogItem.id, descriptorId, documentId, *, *)
.once()
.returns(Future.successful((eService, SpecData.catalogDocument.copy(id = documentId))))

Post() ~> service.getEServiceDocumentById(
eService.id.toString,
descriptorId.toString,
documentId.toString
) ~> check {
status shouldEqual StatusCodes.NotFound
}
}
"fail if Document does not exist" in {

val descriptorId = UUID.randomUUID()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ import it.pagopa.interop.catalogmanagement.model.{
CatalogAttributes,
CatalogDocument,
Published,
CatalogDescriptor,
CatalogDescriptorState,
CatalogItemMode,
Deliver
Expand All @@ -44,6 +45,7 @@ import it.pagopa.interop.attributeregistrymanagement.model.persistence.attribute
import java.time.OffsetDateTime
import java.util.UUID
import scala.concurrent.{ExecutionContext, Future}
import it.pagopa.interop.catalogmanagement.model.Automatic

/**
* Holds fake implementation of dependencies for tests not requiring neither mocks or stubs
Expand Down Expand Up @@ -73,15 +75,50 @@ object FakeDependencies {
override def getEServiceDocument(eServiceId: UUID, descriptorId: UUID, documentId: UUID)(implicit
ec: ExecutionContext,
readModel: ReadModelService
): Future[CatalogDocument] = Future.successful(
CatalogDocument(
id = UUID.randomUUID(),
name = "fake",
contentType = "fake",
prettyName = "fake",
path = "fake",
checksum = "fake",
uploadDate = OffsetDateTime.now()
): Future[(CatalogItem, CatalogDocument)] = Future.successful(
(
CatalogItem(
id = UUID.randomUUID(),
producerId = UUID.randomUUID(),
name = "fake",
description = "fake",
technology = Rest,
descriptors = Seq(
CatalogDescriptor(
id = UUID.randomUUID(),
version = "???",
description = None,
audience = Seq.empty,
voucherLifespan = 0,
dailyCallsPerConsumer = 0,
dailyCallsTotal = 0,
interface = None,
docs = Seq.empty,
state = Published,
agreementApprovalPolicy = Some(Automatic),
serverUrls = Nil,
attributes = CatalogAttributes(Nil, Nil, Nil),
createdAt = OffsetDateTime.now(),
publishedAt = Some(OffsetDateTime.now()),
suspendedAt = None,
deprecatedAt = None,
archivedAt = None
)
),
attributes = Some(CatalogAttributes.empty),
createdAt = OffsetDateTime.now(),
riskAnalysis = Seq.empty,
mode = Deliver
),
CatalogDocument(
id = UUID.randomUUID(),
name = "fake",
contentType = "fake",
prettyName = "fake",
path = "fake",
checksum = "fake",
uploadDate = OffsetDateTime.now()
)
)
)

Expand Down

0 comments on commit 48448ec

Please sign in to comment.