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

pl.touk.nussknacker.engine.migration.ProcessMigration.scala Maven / Gradle / Ivy

The newest version!
package pl.touk.nussknacker.engine.migration

import pl.touk.nussknacker.engine.api.MetaData
import pl.touk.nussknacker.engine.canonicalgraph.{CanonicalProcess, ProcessNodesRewriter}
import pl.touk.nussknacker.engine.graph.node.NodeData

import scala.reflect.ClassTag

trait ProcessMigration {

  def description: String

  // category is used in some of external migrations
  def migrateProcess(canonicalProcess: CanonicalProcess, category: String): CanonicalProcess

}

object ProcessMigrations {

  def empty: ProcessMigrations = new ProcessMigrations {
    override def processMigrations: Map[Int, ProcessMigration] = Map()
  }

  def listOf(migrations: ProcessMigration*): ProcessMigrations = new ProcessMigrations {

    override def processMigrations: Map[Int, ProcessMigration] = migrations.zipWithIndex.map {
      case (processMigration, index) => index + 1 -> processMigration
    }.toMap

  }

}

trait ProcessMigrations extends Serializable {

  def processMigrations: Map[Int, ProcessMigration]

  // we assume 0 is minimal version
  def version: Int = (processMigrations.keys.toSet + 0).max

}

/**
  * It migrates data of each node in process without changing the structure of process graph.
  */
trait NodeMigration extends ProcessMigration {

  def migrateNode(metaData: MetaData): PartialFunction[NodeData, NodeData]

  override def migrateProcess(canonicalProcess: CanonicalProcess, category: String): CanonicalProcess = {
    val rewriter = new ProcessNodesRewriter {
      override protected def rewriteNode[T <: NodeData: ClassTag](data: T)(implicit metaData: MetaData): Option[T] =
        migrateNode(metaData).lift(data).map(_.asInstanceOf[T])
    }
    rewriter.rewriteProcess(canonicalProcess)
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy