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

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

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

package com.cognite.sdk.scala.v1

import com.cognite.sdk.scala.common.OAuth2.ClientCredentials

import java.time.Instant
import com.cognite.sdk.scala.common._
import io.circe.{Decoder, Encoder, Json}
import io.circe.generic.semiauto.{deriveDecoder, deriveEncoder}

final case class TransformationRead(
    id: Long,
    name: String,
    query: String,
    destination: DestinationDataSource,
    conflictMode: String,
    isPublic: Boolean = false,
    blocked: Option[TransformBlacklistInfo],
    createdTime: Instant,
    lastUpdatedTime: Instant,
    owner: TransformationOwner,
    ownerIsCurrentUser: Boolean,
    hasSourceApiKey: Boolean,
    hasDestinationApiKey: Boolean,
    hasSourceOidcCredentials: Boolean,
    hasDestinationOidcCredentials: Boolean,
    lastFinishedJob: Option[JobDetails],
    runningJob: Option[JobDetails],
    externalId: String,
    ignoreNullFields: Boolean,
    dataSetId: Option[Long]
) extends WithId[Long]
    with WithCreatedTime
    with ToCreate[TransformationCreate] {
  override def toCreate: TransformationCreate =
    TransformationCreate(
      name = name,
      query = Some(query),
      destination = Some(destination),
      conflictMode = Some(conflictMode),
      isPublic = Some(isPublic),
      sourceApiKey = None,
      destinationApiKey = None,
      sourceOidcCredentials = None,
      destinationOidcCredentials = None,
      externalId = externalId,
      ignoreNullFields = ignoreNullFields,
      dataSetId = dataSetId
    )
}

final case class TransformBlacklistInfo(
    reason: String,
    createdTime: Instant
)
object TransformBlacklistInfo {
  implicit val transformBlacklistInfoEncoder: Encoder[TransformBlacklistInfo] =
    deriveEncoder[TransformBlacklistInfo]
  implicit val transformBlacklistInfoDecoder: Decoder[TransformBlacklistInfo] =
    deriveDecoder[TransformBlacklistInfo]
}

final case class TransformationOwner(user: String)
object TransformationOwner {
  implicit val transformationOwnerEncoder: Encoder[TransformationOwner] =
    deriveEncoder[TransformationOwner]
  implicit val transformationOwnerDecoder: Decoder[TransformationOwner] =
    deriveDecoder[TransformationOwner]
}

sealed trait DestinationDataSource
sealed case class GenericDataSource(`type`: String) extends DestinationDataSource
sealed case class RawDataSource(`type`: String, database: String, table: String)
    extends DestinationDataSource

sealed case class SequenceRowDataSource(`type`: String, externalId: String)
    extends DestinationDataSource

final case class TransformationRun(externalId: String)

final case class JobDetails(
    id: Long,
    uuid: String,
    transformationId: Long,
    transformationExternalId: String,
    sourceProject: String,
    destinationProject: String,
    destination: DestinationDataSource,
    conflictMode: String,
    query: String,
    createdTime: Option[Long],
    startedTime: Option[Long],
    finishedTime: Option[Long],
    lastSeenTime: Option[Long],
    error: Option[String],
    ignoreNullFields: Boolean,
    status: String
)

object FlatOidcCredentials {
  implicit val credentialEncoder: Encoder[ClientCredentials] =
    new Encoder[ClientCredentials] {
      final def apply(cc: ClientCredentials): Json = {
        val scopes = Option(cc.scopes).filter(_.nonEmpty).map(_.mkString(" "))
        Json.fromFields(
          Seq(
            "clientId" -> Json.fromString(cc.clientId),
            "clientSecret" -> Json.fromString(cc.clientSecret),
            "tokenUri" -> Json.fromString(cc.tokenUri.toString()),
            "cdfProjectName" -> Json.fromString(cc.cdfProjectName)
          ) ++ cc.audience.map(a => Seq("audience" -> Json.fromString(a))).getOrElse(Seq()) ++
            scopes.map(s => Seq("scopes" -> Json.fromString(s))).getOrElse(Seq())
        )
      }
    }
}

final case class TransformationCreate(
    name: String,
    query: Option[String] = None,
    destination: Option[DestinationDataSource] = None,
    conflictMode: Option[String] = None,
    isPublic: Option[Boolean] = None,
    sourceApiKey: Option[String] = None,
    destinationApiKey: Option[String] = None,
    sourceOidcCredentials: Option[ClientCredentials] = None,
    destinationOidcCredentials: Option[ClientCredentials] = None,
    externalId: String,
    ignoreNullFields: Boolean,
    dataSetId: Option[Long]
)

final case class TimeFilter(
    min: Option[Long] = None,
    max: Option[Long] = None
)

object TimeFilter {
  implicit val timeFilterEncoder: Encoder[TimeFilter] = deriveEncoder[TimeFilter]
  implicit val timeFilterDecoder: Decoder[TimeFilter] = deriveDecoder[TimeFilter]
}

final case class TransformationsFilter(
    isPublic: Option[Boolean] = None,
    nameRegex: Option[String] = None,
    queryRegex: Option[String] = None,
    destinationType: Option[String] = None,
    conflictMode: Option[String] = None,
    hasBlockedError: Option[Boolean] = None,
    cdfProjectName: Option[String] = None,
    createdTime: Option[TimeFilter] = None,
    lastUpdatedTime: Option[TimeFilter] = None,
    dataSetIds: Option[Seq[CogniteId]] = None
)

object TransformationsFilter {
  implicit val transformationsFilterEncoder: Encoder[TransformationsFilter] =
    deriveEncoder[TransformationsFilter]
  implicit val transformationsFilterDecoder: Decoder[TransformationsFilter] =
    deriveDecoder[TransformationsFilter]
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy