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

scray.cassandra.util.CassandraPropertyUtils.scala Maven / Gradle / Ivy

There is a newer version: 1.1.2
Show newest version
// See the LICENCE.txt file distributed with this work for additional
// information regarding copyright ownership.
//
// 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 scray.cassandra.util

import java.net.InetSocketAddress

import scray.common.properties.{Property, ScrayProperties, ScrayPropertyRegistration}
import scray.common.properties.predefined.{CommonCassandraLoader, CommonCassandraRegistrar, PredefinedProperties}
import scray.common.tools.ScrayCredentials

import scala.collection.JavaConverters.asScalaSetConverter

/**
 * utility functions for configurable Cassandra properties
 */
object CassandraPropertyUtils {

  def getCassandraClusterProperty() : String = ScrayProperties.getPropertyValue(PredefinedProperties.CASSANDRA_QUERY_CLUSTER_NAME)
  
  def getCassandraClusterCredentials() : ScrayCredentials = ScrayProperties.getPropertyValue(PredefinedProperties.CASSANDRA_QUERY_CLUSTER_CREDENTIALS)
  
  def getCassandraHostProperty() : Set[String] = ScrayProperties.getPropertyValue(PredefinedProperties.CASSANDRA_QUERY_SEED_IPS).
    asScala.toSet[InetSocketAddress].map(inetsocket => s"${inetsocket.getHostString}:${inetsocket.getPort}")

  def performDefaultPropertySystemInitialization(additionPropertiesToRegister : Set[Property[_, _]] = Set()) : Unit = {
    additionPropertiesToRegister.foreach(ScrayProperties.registerProperty(_))
    ScrayPropertyRegistration.addRegistrar(new CommonCassandraRegistrar)
    ScrayPropertyRegistration.addLoader(new CommonCassandraLoader)
    ScrayPropertyRegistration.performPropertySetup
    
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy