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

lucuma.catalog.votable.CatalogProblem.scala Maven / Gradle / Ivy

There is a newer version: 0.48.7
Show newest version
// Copyright (c) 2016-2023 Association of Universities for Research in Astronomy, Inc. (AURA)
// For license information see LICENSE or https://opensource.org/licenses/BSD-3-Clause

package lucuma.catalog.votable

import cats.syntax.all.*
import lucuma.core.enums.CatalogName

/** Indicates an issue parsing the targets, e.g. missing values, bad format, etc. */
sealed trait CatalogProblem extends Throwable with Product with Serializable {
  def displayValue: String

  override def toString(): String = displayValue
}

object CatalogProblem {
  case class ValidationError(catalog: CatalogName)              extends CatalogProblem {
    val displayValue = s"Invalid response from $catalog"
  }
  case class InvalidFieldId(id: String)                         extends CatalogProblem {
    val displayValue = s"Invalid field id: '$id'"
  }
  case class UnknownXmlTag(tag: String)                         extends CatalogProblem {
    val displayValue = s"Unknown tag: '$tag'"
  }
  case class MissingXmlTag(tag: String)                         extends CatalogProblem {
    val displayValue = s"Missing tag: '$tag'"
  }
  case class MissingXmlAttribute(attr: String)                  extends CatalogProblem {
    val displayValue = s"Missing attr: '$attr'"
  }
  case class InvalidUcd(ucd: String)                            extends CatalogProblem {
    val displayValue = s"Invalid ucd: '$ucd'"
  }
  case class GenericError(msg: String)                          extends CatalogProblem {
    val displayValue = msg
  }
  case class UnexpectedTag(tag: String)                         extends CatalogProblem {
    val displayValue = s"Unexpected tag $tag"
  }
  case object NoFieldsFound                                     extends CatalogProblem {
    val displayValue = s"No fields defined"
  }
  case object ExtraRow                                          extends CatalogProblem {
    val displayValue = s"Extra row in the data"
  }
  case object MissingRow                                        extends CatalogProblem {
    val displayValue = s"Missing row in the data"
  }
  case class MissingValue(field: FieldId)                       extends CatalogProblem {
    val displayValue = s"Missing required field '${field.id}'"
  }
  case class FieldValueProblem(ucd: Option[Ucd], value: String) extends CatalogProblem {
    val displayValue = s"Error parsing field ${ucd.foldMap(_.toString)} with value $value"
  }
  case class UnsupportedField(field: FieldId)                   extends CatalogProblem {
    val displayValue = s"Unsupported field $field"
  }
  case class UnmatchedField(ucd: Option[Ucd])                   extends CatalogProblem {
    val displayValue = s"Unmatched field ${ucd.foldMap(_.toString)}"
  }
  case object UnknownCatalog                                    extends CatalogProblem {
    val displayValue = s"Requested an unknown catalog"
  }

  case class CatalogException(problems: List[CatalogProblem])
      extends RuntimeException(problems.mkString(", ")) {
    def firstMessage: String =
      problems.headOption.map {
        case e: GenericError => e.msg
        case e               => e.toString
      }.orEmpty
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy