libminifi/include/EventDrivenSchedulingAgent.h (32 lines of code) (raw):

/** * @file EventDrivenSchedulingAgent.h * EventDrivenSchedulingAgent class declaration * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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. */ #pragma once #include <memory> #include <string> #include <chrono> constexpr auto DEFAULT_TIME_SLICE = std::chrono::milliseconds(500); #include "core/logging/Logger.h" #include "core/Processor.h" #include "core/ProcessContext.h" #include "core/ProcessSessionFactory.h" #include "ThreadedSchedulingAgent.h" namespace org::apache::nifi::minifi { class EventDrivenSchedulingAgent : public ThreadedSchedulingAgent { public: EventDrivenSchedulingAgent(const gsl::not_null<core::controller::ControllerServiceProvider*> controller_service_provider, std::shared_ptr<core::Repository> repo, std::shared_ptr<core::Repository> flow_repo, std::shared_ptr<core::ContentRepository> content_repo, std::shared_ptr<Configure> configuration, utils::ThreadPool &thread_pool) : ThreadedSchedulingAgent(controller_service_provider, repo, flow_repo, content_repo, configuration, thread_pool) { using namespace std::literals::chrono_literals; time_slice_ = configuration->get(Configure::nifi_flow_engine_event_driven_time_slice) | utils::andThen(utils::timeutils::StringToDuration<std::chrono::milliseconds>) | utils::valueOrElse([] { return DEFAULT_TIME_SLICE; }); if (time_slice_ < 10ms || 1000ms < time_slice_) { throw Exception(FLOW_EXCEPTION, std::string(Configure::nifi_flow_engine_event_driven_time_slice) + " is out of reasonable range!"); } } void schedule(core::Processor* processor) override; utils::TaskRescheduleInfo run(core::Processor* processor, const std::shared_ptr<core::ProcessContext> &process_context, const std::shared_ptr<core::ProcessSessionFactory> &session_factory) override; private: std::chrono::milliseconds time_slice_{}; }; } // namespace org::apache::nifi::minifi