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

com.datastax.spark.connector.util.RefBuilder.scala Maven / Gradle / Ivy

package com.datastax.spark.connector.util

import com.datastax.spark.connector.cql.{AuthConfFactory, CassandraConnectionFactory}

object RefBuilder {

  val Header =
    """# Configuration Reference
      |
      |
    """.stripMargin
  val Footer = "\n"

  val HtmlTableHeader =
    """
      |""".stripMargin

  val allConfigs = ConfigCheck.validStaticProperties

  def getMarkDown(): String = {
    val configBySection = allConfigs.groupBy(x => x.section)
    val sections = configBySection.keys.toSeq.sorted
    val markdown = for (section <- sections) yield {
      val parameters = configBySection.get(section).get
      val paramTable = parameters.toList.sortBy(_.name).map { case parameter: ConfigParameter[_] =>
        val default = parameter.default match {
          case x: CassandraConnectionFactory => x.getClass.getSimpleName.stripSuffix("$")
          case x: AuthConfFactory => x.getClass.getSimpleName.stripSuffix("$")
          case x: Seq[_] => x.mkString(",")
          case Some(defaultValue) => defaultValue
          case None => None
          case value => value
        }
        s"""
            |  
            |  
            |  
            |""".stripMargin
      }.mkString("\n")

      s"""
         |## $section
         |**All parameters should be prefixed with  spark.cassandra. **
         |
         |$HtmlTableHeader
         |$paramTable
         |
Property NameDefaultDescription
${parameter.name.stripPrefix("spark.cassandra.")}$default${parameter.description}
""".stripMargin } Header + markdown.mkString("\n\n") + Footer } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy