in libminifi/include/core/ProcessContext.h [280:366]
static std::shared_ptr<core::StateStorage> getOrCreateDefaultStateStorage(
controller::ControllerServiceProvider* controller_service_provider,
const std::shared_ptr<minifi::Configure>& configuration) {
static std::mutex mutex;
std::lock_guard<std::mutex> lock(mutex);
/* See if we have already created a default provider */
std::shared_ptr<core::controller::ControllerServiceNode> node = controller_service_provider->getControllerServiceNode(DefaultStateStorageName);
if (node != nullptr) {
return std::dynamic_pointer_cast<core::StateStorage>(node->getControllerServiceImplementation());
}
/* Try to get configuration options for default provider */
std::string always_persist;
configuration->get(Configure::nifi_state_storage_local_always_persist, Configure::nifi_state_storage_local_always_persist_old, always_persist);
std::string auto_persistence_interval;
configuration->get(Configure::nifi_state_storage_local_auto_persistence_interval, Configure::nifi_state_storage_local_auto_persistence_interval_old, auto_persistence_interval);
const auto path = configuration->getWithFallback(Configure::nifi_state_storage_local_path, Configure::nifi_state_storage_local_path_old);
/* Function to help creating a state storage */
auto create_provider = [&](
const std::string& type,
const std::string& longType,
const std::unordered_map<std::string, std::string>& extraProperties) -> std::shared_ptr<core::StateStorage> {
node = controller_service_provider->createControllerService(type, longType, DefaultStateStorageName, true /*firstTimeAdded*/);
if (node == nullptr) {
return nullptr;
}
node->initialize();
auto storage = node->getControllerServiceImplementation();
if (storage == nullptr) {
return nullptr;
}
if (!always_persist.empty() && !storage->setProperty(controllers::ALWAYS_PERSIST_PROPERTY_NAME, always_persist)) {
return nullptr;
}
if (!auto_persistence_interval.empty() && !storage->setProperty(controllers::AUTO_PERSISTENCE_INTERVAL_PROPERTY_NAME, auto_persistence_interval)) {
return nullptr;
}
for (const auto& extraProperty : extraProperties) {
if (!storage->setProperty(extraProperty.first, extraProperty.second)) {
return nullptr;
}
}
if (!node->enable()) {
return nullptr;
}
return std::dynamic_pointer_cast<core::StateStorage>(storage);
};
std::string preferredType;
configuration->get(minifi::Configure::nifi_state_storage_local_class_name, minifi::Configure::nifi_state_storage_local_class_name_old, preferredType);
/* Try to create a RocksDB-backed provider */
if (preferredType.empty() || preferredType == "RocksDbPersistableKeyValueStoreService" || preferredType == "RocksDbStateStorage") {
auto provider = create_provider("RocksDbStateStorage",
"org.apache.nifi.minifi.controllers.RocksDbStateStorage",
{{"Directory", path.value_or("corecomponentstate")}});
if (provider != nullptr) {
return provider;
}
}
/* Fall back to a locked unordered map-backed provider */
if (preferredType.empty() || preferredType == "UnorderedMapPersistableKeyValueStoreService" || preferredType == "PersistentMapStateStorage") {
auto provider = create_provider("PersistentMapStateStorage",
"org.apache.nifi.minifi.controllers.PersistentMapStateStorage",
{{"File", path.value_or("corecomponentstate.txt")}});
if (provider != nullptr) {
return provider;
}
}
/* Fall back to volatile memory-backed provider */
if (preferredType.empty() || preferredType == "UnorderedMapKeyValueStoreService" || preferredType == "VolatileMapStateStorage") {
auto provider = create_provider("VolatileMapStateStorage",
"org.apache.nifi.minifi.controllers.VolatileMapStateStorage",
{});
if (provider != nullptr) {
return provider;
}
}
/* Give up */
return nullptr;
}