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

org.apache.eventmesh.protocol.api.ProtocolAdaptor Maven / Gradle / Ivy

There is a newer version: 1.11.0-release
Show newest version
/*
 * 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.
 */

package org.apache.eventmesh.protocol.api;

import org.apache.eventmesh.common.protocol.ProtocolTransportObject;
import org.apache.eventmesh.protocol.api.exception.ProtocolHandleException;
import org.apache.eventmesh.spi.EventMeshExtensionType;
import org.apache.eventmesh.spi.EventMeshSPI;

import java.util.List;

import io.cloudevents.CloudEvent;

/**
 * Protocol transformer SPI interface, all protocol plugin should implementation.
 *
 * 

All protocol stored in EventMesh is {@link CloudEvent}. * * @since 1.3.0 */ @EventMeshSPI(eventMeshExtensionType = EventMeshExtensionType.PROTOCOL) public interface ProtocolAdaptor { /** * transform protocol to {@link CloudEvent}. * * @param protocol input protocol * @return cloud event */ CloudEvent toCloudEvent(T protocol) throws ProtocolHandleException; /** * transform protocol to {@link CloudEvent} list. * * @param protocol input protocol * @return list cloud event */ List toBatchCloudEvent(T protocol) throws ProtocolHandleException; /** * Transform {@link CloudEvent} to target protocol. * * @param cloudEvent clout event * @return target protocol */ ProtocolTransportObject fromCloudEvent(CloudEvent cloudEvent) throws ProtocolHandleException; /** * Get protocol type. * * @return protocol type, protocol type should not be null */ String getProtocolType(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy