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

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