* Copyright (c) Huawei Technologies Co., Ltd. 2025. All rights reserved.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
* http://license.coscl.org.cn/MulanPSL2
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
*/
#ifndef OMNISTREAM_TASKOPERATOREVENTGATEWAY_H
#define OMNISTREAM_TASKOPERATOREVENTGATEWAY_H
#include "../OperatorID.h"
#include "operators/coordination/AcknowledgeCheckpointEvent.h"
#include "runtime/operators/coordination/OperatorEvent.h"
#include "runtime/state/bridge/TaskOperatorEventGatewayBridge.h"
class TaskOperatorEventGateway {
public:
explicit TaskOperatorEventGateway(const std::shared_ptr<TaskOperatorEventGatewayBridge> &bridge)
: bridge_(bridge) {
}
std::shared_ptr<TaskOperatorEventGatewayBridge> bridge_;
* Sends an event from the operator (identified by the given operator ID) to the operator
* coordinator (identified by the same ID).
*/
virtual void SendOperatorEventToCoordinator(OperatorID operatorId, std::shared_ptr<OperatorEvent> event)
{
std::string operatorIdJson = operatorId.toString();
std::string eventJson = event->toString();
if (bridge_ != nullptr) {
bridge_->sendOperatorEventToCoordinator(operatorIdJson, eventJson);
}
}
virtual ~TaskOperatorEventGateway() = default;
* Sends a request from current operator to a specified operator coordinator which is identified
* by the given operator ID and return the response.
*/
};
#endif