
org.scassandra.server.priming.routes.PrimingQueryRoute.scala Maven / Gradle / Ivy
The newest version!
/*
* Copyright (C) 2014 Christopher Batey and Dogan Narinc
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.scassandra.server.priming.routes
import spray.routing.HttpService
import com.typesafe.scalalogging.slf4j.Logging
import spray.http.StatusCodes
import org.scassandra.server.priming._
import org.scassandra.server.priming.query._
import org.scassandra.server.priming.query.PrimeCriteria
import org.scassandra.server.priming.query.PrimeQuerySingle
import org.scassandra.server.priming.query.Prime
import scala.util.{Success, Failure}
trait PrimingQueryRoute extends HttpService with Logging {
import PrimingJsonImplicits._
implicit val primeQueryStore: PrimeQueryStore
val queryRoute = {
path("prime-query-sequence") {
post {
complete {
// TODO - implement multi primes
StatusCodes.NotFound
}
}
} ~
path("prime-query-single") {
get {
complete {
val allPrimes: Map[PrimeCriteria, Prime] = primeQueryStore.getAllPrimes
PrimeQueryResultExtractor.convertBackToPrimeQueryResult(allPrimes)
}
} ~
post {
entity(as[PrimeQuerySingle]) {
primeRequest => {
complete {
logger.debug(s"Received prime request $primeRequest")
val primeCriteriaTry = PrimeQueryResultExtractor.extractPrimeCriteria(primeRequest)
primeCriteriaTry match {
case Success(primeCriteria) =>
val primeResult = PrimeQueryResultExtractor.extractPrimeResult(primeRequest)
primeQueryStore.add(primeCriteria, primeResult) match {
case cp: ConflictingPrimes => {
logger.warn(s"Received invalid prime due to conflicting primes $cp")
StatusCodes.BadRequest -> cp
}
case tm: TypeMismatches => {
logger.warn(s"Received invalid prime due to type mismatch $tm")
StatusCodes.BadRequest -> tm
}
case _ => StatusCodes.OK
}
case failure @ Failure(_) => {
logger.warn(s"Received invalid prime $failure")
StatusCodes.BadRequest
}
}
}
}
}
} ~
delete {
complete {
logger.debug("Deleting all recorded priming")
primeQueryStore.clear()
logger.debug("Return 200")
StatusCodes.OK
}
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy