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

ai.agnos.sparql.api.GraphStoreProtocol.scala Maven / Gradle / Ivy

The newest version!
package ai.agnos.sparql.api

import java.net.URL
import java.nio.file.Path

import akka.http.scaladsl.model.HttpMethod
import akka.http.scaladsl.model.HttpMethods._
import org.eclipse.rdf4j.model.{IRI, Model}
import org.eclipse.rdf4j.rio.RDFFormat
import org.eclipse.rdf4j.rio.RDFFormat.NTRIPLES


/**
  * Implementation of the graph-store API messages.
  */
trait GraphStoreProtocol extends ClientAPIProtocol

abstract class GraphStoreRequest extends ClientHttpRequest with GraphStoreProtocol {
  def context: Option[Any]
}

/**
  * The response entity for graph store operations.
  * @param request    the request object
  * @param success    true if the operation was successful
  * @param statusCode the HTTP status code of the response
  * @param statusText the HTTP status reason text
  * @param model      the response RDF graph (model) if available
  */
case class GraphStoreResponse
(
  request: GraphStoreRequest,
  success: Boolean,
  statusCode: Int,
  statusText: String,
  model: Option[Model] = None
) extends ClientHttpResponse with GraphStoreProtocol

object GetGraphM {
  def unapply(arg: GetGraph): Option[(Option[IRI], HttpMethod)] = {
    Some((arg.graphIri, arg.httpMethod))
  }
}

/**
  * Represents the operation to retrieve a single graph via the graph-store protocol.
  * @param graphIri the graph IRI to get, if not specified this denotes the DEFAULT graph
  *
  * @see [[https://www.w3.org/TR/2013/REC-sparql11-http-rdf-update-20130321/#http-get]]
  */
case class GetGraph(graphIri: Option[IRI], context: Option[Any] = None) extends GraphStoreRequest {
  final override val httpMethod: HttpMethod = GET
}


object DropGraphM {
  def unapply(arg: DropGraph): Option[(Option[IRI], HttpMethod)] = {
    Some((arg.graphIri, arg.httpMethod))
  }
}

/**
  * Represents an operation to drop a single graph via the graph-store protocol.
  * @param graphIri the graph IRI to drop, if not specified this denotes the DEFAULT graph
  *
  * @see [[https://www.w3.org/TR/2013/REC-sparql11-http-rdf-update-20130321/#http-delete]]
  */
case class DropGraph(graphIri: Option[IRI], context: Option[Any] = None) extends GraphStoreRequest {
  final override val httpMethod: HttpMethod = DELETE
}


/**
  * Represents an operation to insert graph(s) via the graph-store protocol.
  * @param graphIri    an optional graph IRI specifier, will be added as the value of the "?graph=uri"
  *                    query parameter
  * @param mergeGraphs merge if true, replace graph if false
  *
  * @see [[https://www.w3.org/TR/2013/REC-sparql11-http-rdf-update-20130321/#http-post]]
  * @see [[https://www.w3.org/TR/2013/REC-sparql11-http-rdf-update-20130321/#http-put]]

  */
abstract class InsertGraph(val graphIri: Option[IRI], val mergeGraphs: Boolean)
  extends GraphStoreRequest {

  override val httpMethod: HttpMethod = if (mergeGraphs) POST else PUT

  val modelFormat: RDFFormat
}

object InsertGraphFromModelM {

   def unapply(arg: InsertGraphFromModel): Option[(Model, RDFFormat, Option[IRI], HttpMethod)] = {
    Some((arg.graphModel, arg.modelFormat, arg.graphIri, arg.httpMethod))
  }
}

/**
  * Used to insert an in-memory RDF model into the triple store.
  * @param graphModel  the graph model
  * @param graphIri    optional graph IRI, defaults to None
  * @param mergeGraphs indicates if the inserted data should be merged data already in the specified graph in
  *                    the database, if set to false the previously stored data in the graph will be replaced
  *                    with the payload, defaults to false
  * @param context     an optional context to be carried along the flow
  */
case class InsertGraphFromModel
(
  graphModel: Model,
  override val graphIri: Option[IRI] = None,
  override val mergeGraphs: Boolean = false,
  context: Option[Any] = None
) extends InsertGraph(graphIri, mergeGraphs) {

  /**
    * We only use NTRIPLES upload format when uploading in-memory Models.
    */
  final override val modelFormat: RDFFormat = NTRIPLES

}


object InsertGraphFromURLM {
  def unapply(arg: InsertGraphFromURL): Option[(URL, RDFFormat, Option[IRI], HttpMethod)] = {
    Some((arg.url, arg.modelFormat, arg.graphIri, arg.httpMethod))
  }
}

/**
  * Used to insert RDF contents from a file or another resource into the triple store.
  * @param url         the URL of the file to use
  * @param modelFormat the RDF format to use, supporting all formats available in org.eclipse.rdf4j.rio.Rio
  * @param graphIri    an optional graph IRI, will insert into the default graph if no graph is specified.
  *                    NB: if the incoming RDF is in "quads" format, i.e. NQUADS
  *                    or JSON-LD, the graph
  *                    in the RDF is ignored and instead the graphIri property is used.
  * @param mergeGraphs indicates if the inserted data should be merged data already in the specified graph in
  *                    the database, if set to false the previously stored data in the graph will be replaced
  *                    with the payload, defaults to false
  * @param context     an optional context to be carried along the flow
  */
case class InsertGraphFromURL
(
  url: URL,
  modelFormat: RDFFormat,
  override val graphIri: Option[IRI] = None,
  override val mergeGraphs: Boolean = false,
  context: Option[Any] = None
) extends InsertGraph(graphIri, mergeGraphs)

object InsertGraphFromPathM {
  def unapply(arg: InsertGraphFromPath): Option[(Path, RDFFormat, Option[IRI], HttpMethod)] = {
    Some((arg.path, arg.modelFormat, arg.graphIri, arg.httpMethod))
  }
}

/**
  * Used to insert RDF contents from a file or another resource into the triple store.
  * @param path        the local filesystem path of the file to use
  * @param modelFormat the RDF format to use, supporting all formats available in org.eclipse.rdf4j.rio.Rio
  * @param graphIri    an optional graph IRI, will insert into the default graph if no graph is specified.
  *                    NB: if the incoming RDF is in "quads" format, i.e. NQUADS
  *                    or JSON-LD, the graph
  *                    in the RDF is ignored and instead the graphIri property is used.
  * @param mergeGraphs indicates if the inserted data should be merged data already in the specified graph in
  *                    the database, if set to false the previously stored data in the graph will be replaced
  *                    with the payload, defaults to false
  * @param context     an optional context to be carried along the flow
  */
case class InsertGraphFromPath
(
  path: Path,
  modelFormat: RDFFormat,
  override val graphIri: Option[IRI] = None,
  override val mergeGraphs: Boolean = false,
  context: Option[Any] = None
) extends InsertGraph(graphIri, mergeGraphs)




© 2015 - 2025 Weber Informatics LLC | Privacy Policy