All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.cognite.sdk.scala.v1.resources.transformations.scala Maven / Gradle / Ivy

// Copyright 2020 Cognite AS
// SPDX-License-Identifier: Apache-2.0

package com.cognite.sdk.scala.v1.resources

import cats.implicits.toFunctorOps
import com.cognite.sdk.scala.common._
import com.cognite.sdk.scala.v1._
import io.circe.generic.semiauto.{deriveDecoder, deriveEncoder}
import io.circe.{Decoder, Encoder}
import sttp.client3._
import sttp.client3.circe._

class Transformations[F[_]](val requestSession: RequestSession[F])
    extends WithRequestSession[F]
    with Create[TransformationRead, TransformationCreate, F]
    with RetrieveByIdsWithIgnoreUnknownIds[TransformationRead, F]
    with Readable[TransformationRead, F]
    with RetrieveByExternalIdsWithIgnoreUnknownIds[TransformationRead, F]
    with PartitionedFilter[TransformationRead, TransformationsFilter, F]
    with DeleteByCogniteIds[F] {
  import Transformations._
  override val baseUrl = uri"${requestSession.baseUrl}/transformations"

  override private[sdk] def readWithCursor(
      cursor: Option[String],
      limit: Option[Int],
      partition: Option[Partition]
  ): F[ItemsWithCursor[TransformationRead]] =
    Readable.readWithCursor(
      requestSession,
      baseUrl,
      cursor,
      limit,
      partition,
      1000
    )

  override def retrieveByIds(
      ids: Seq[Long],
      ignoreUnknownIds: Boolean
  ): F[Seq[TransformationRead]] =
    RetrieveByIdsWithIgnoreUnknownIds.retrieveByIds(
      requestSession,
      baseUrl,
      ids,
      ignoreUnknownIds
    )

  override def retrieveByExternalIds(
      externalIds: Seq[String],
      ignoreUnknownIds: Boolean
  ): F[Seq[TransformationRead]] =
    RetrieveByExternalIdsWithIgnoreUnknownIds.retrieveByExternalIds(
      requestSession,
      baseUrl,
      externalIds,
      ignoreUnknownIds
    )

  override def createItems(items: Items[TransformationCreate]): F[Seq[TransformationRead]] =
    Create.createItems[F, TransformationRead, TransformationCreate](
      requestSession,
      baseUrl,
      items
    )

  override def delete(ids: Seq[CogniteId], ignoreUnknownIds: Boolean = false): F[Unit] =
    DeleteByCogniteIds.deleteWithIgnoreUnknownIds(
      requestSession,
      baseUrl,
      ids,
      ignoreUnknownIds
    )

  def filter(
      filter: TransformationsFilter,
      limit: Option[Int],
      aggregatedProperties: Option[Seq[String]]
  ): fs2.Stream[F, TransformationRead] =
    filterWithNextCursor(filter, None, limit, aggregatedProperties)

  def filterPartitions(
      filter: TransformationsFilter,
      numPartitions: Int,
      limitPerPartition: Option[Int],
      aggregatedProperties: Option[Seq[String]]
  ): Seq[fs2.Stream[F, TransformationRead]] =
    1.to(numPartitions).map { i =>
      Readable
        .pullFromCursor(
          None,
          limitPerPartition,
          Some(Partition(i, numPartitions)),
          filterWithCursor(filter, _, _, _, aggregatedProperties)
        )
        .stream
    }

  private[sdk] def filterWithCursor(
      filter: TransformationsFilter,
      cursor: Option[String],
      limit: Option[Int],
      partition: Option[Partition],
      aggregatedProperties: Option[Seq[String]] = None
  ): F[ItemsWithCursor[TransformationRead]] =
    Filter.filterWithCursor(
      requestSession,
      uri"$baseUrl/filter",
      filter,
      cursor,
      limit,
      partition,
      Constants.defaultBatchSize,
      aggregatedProperties
    )

  def run(externalId: String): F[JobDetails] =
    requestSession.post[JobDetails, JobDetails, TransformationRun](
      TransformationRun(externalId),
      uri"$baseUrl/run",
      value => value
    )

  def retrieveJobByIds(ids: Seq[Long], ignoreUnknownIds: Boolean = true): F[Seq[JobDetails]] =
    requestSession
      .post[Seq[JobDetails], Items[JobDetails], ItemsWithIgnoreUnknownIds[CogniteInternalId]](
        ItemsWithIgnoreUnknownIds(ids.map(CogniteInternalId.apply), ignoreUnknownIds),
        uri"$baseUrl/jobs/byids",
        value => value.items
      )
}

object Transformations {
  implicit val generalDataSourceDecoder: Decoder[GenericDataSource] =
    deriveDecoder[GenericDataSource]
  implicit val rawDataSourceDecoder: Decoder[RawDataSource] = deriveDecoder[RawDataSource]
  implicit val seqRowDataSourceDecoder: Decoder[SequenceRowDataSource] =
    deriveDecoder[SequenceRowDataSource]

  implicit val destinationDataSourceDecoder: Decoder[DestinationDataSource] =
    List[Decoder[DestinationDataSource]](
      Decoder[GenericDataSource].widen,
      Decoder[RawDataSource].widen,
      Decoder[SequenceRowDataSource].widen
    ).reduceLeftOption(_ or _).getOrElse(Decoder[GenericDataSource].widen)

  implicit val jobDetailDecoder: Decoder[JobDetails] = deriveDecoder[JobDetails]
  implicit val jobDetailItemsDecoder: Decoder[Items[JobDetails]] = deriveDecoder[Items[JobDetails]]

  implicit val readDecoder: Decoder[TransformationRead] = deriveDecoder[TransformationRead]
  implicit val readItemsWithCursorDecoder: Decoder[ItemsWithCursor[TransformationRead]] =
    deriveDecoder[ItemsWithCursor[TransformationRead]]
  implicit val readItemsDecoder: Decoder[Items[TransformationRead]] =
    deriveDecoder[Items[TransformationRead]]

  implicit val generalDataSourceEncoder: Encoder[GenericDataSource] =
    deriveEncoder[GenericDataSource]
  implicit val rawDataSourceEncoder: Encoder[RawDataSource] = deriveEncoder[RawDataSource]
  implicit val sequenceRowDataSourceEncoder: Encoder[SequenceRowDataSource] =
    deriveEncoder[SequenceRowDataSource]

  implicit val destinationDataSourceEncoder: Encoder[DestinationDataSource] = Encoder.instance {
    case g: GenericDataSource => generalDataSourceEncoder(g)
    case r: RawDataSource => rawDataSourceEncoder(r)
    case sr: SequenceRowDataSource => sequenceRowDataSourceEncoder(sr)
  }

  import FlatOidcCredentials.credentialEncoder

  implicit val createEncoder: Encoder[TransformationCreate] = deriveEncoder[TransformationCreate]
  implicit val createItemsEncoder: Encoder[Items[TransformationCreate]] =
    deriveEncoder[Items[TransformationCreate]]

  implicit val errorOrUnitDecoder: Decoder[Either[CdpApiError, Unit]] =
    EitherDecoder.eitherDecoder[CdpApiError, Unit]
  implicit val deleteRequestWithRecursiveAndIgnoreUnknownIdsEncoder
      : Encoder[ItemsWithRecursiveAndIgnoreUnknownIds] =
    deriveEncoder[ItemsWithRecursiveAndIgnoreUnknownIds]
  implicit val cogniteExternalIdDecoder: Decoder[CogniteExternalId] =
    deriveDecoder[CogniteExternalId]

  implicit val transformationsFilterRequestEncoder: Encoder[FilterRequest[TransformationsFilter]] =
    deriveEncoder[FilterRequest[TransformationsFilter]]

  implicit val transformationRunEncoder: Encoder[TransformationRun] =
    deriveEncoder[TransformationRun]

  implicit val itemsWithIgnoreUnknownIdsEncoder
      : Encoder[ItemsWithIgnoreUnknownIds[CogniteInternalId]] =
    deriveEncoder[ItemsWithIgnoreUnknownIds[CogniteInternalId]]

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy