Eclipse 数据空间组件-实现简单的事件消费者-6

在这个示例中,可以基于Eclipse 数据空间组件-实现简单的"Provider Push"Http传输流程-4Eclipse 数据空间组件-实现简单的"Consumer Pull"Http传输流程-5进行

此外,为了保持项目的条理性,此示例中的代码被分成2个 Java 模块:

  • consumer-with-listener:将由事件消费者扩展的消费者连接器
  • listener:包含TransferProcessListener将使用事件的实现

增加监听器

可以参考官方文档

TransferProcessListener接口定义了数据在传输状态后改变后调用的方法,例如,在生成数据后(即传输转移到完成状态)通知消费者端的外部应用程序。

typescript 复制代码
// in TransferProcessStartedListenerExtension.java
    @Override
    public void initialize(ServiceExtensionContext context) {
        var transferProcessObservable = context.getService(TransferProcessObservable.class);
        var monitor = context.getMonitor();
        transferProcessObservable.registerListener(new TransferProcessStartedListener(monitor));
    }

实现TransferProcessListener接口类TransferProcessStartedListener。它将使用传输STARTED事件并写入日志消息。

java 复制代码
public class TransferProcessStartedListener implements TransferProcessListener {

    private final Monitor monitor;

    public TransferProcessStartedListener(Monitor monitor) {
        this.monitor = monitor;
    }

    /**
     * Callback invoked by the EDC framework when a transfer is about to be completed.
     *
     * @param process the transfer process that is about to be completed.
     */
    @Override
    public void preStarted(final TransferProcess process) {
        monitor.debug("TransferProcessStartedListener received STARTED event");
        // do something meaningful before transfer start
    }
}

运行示例

假设您的提供商连接器和日志网络服务器仍在运行,我们可以重新使用提供商端存储的现有资产和合同定义。如果没有,请按照Eclipse 数据空间组件-EDCSample 操作样例 Transfer 合同谈判-3中的说明设置您的资产和合同定义。

1. 编译监听器扩展程序并启动消费者

参考官方文档

此消费者连接器基于不同的构建文件,因此将构建一个新的 JAR 文件。请确保从前面的章节中终止当前的消费者连接器。这样我们就可以解除端口阻塞并重用已知的配置文件和 API 调用。

运行此程序来构建并启动带有监听器扩展的消费者:

arduino 复制代码
./gradlew transfer:transfer-04-event-consumer:consumer-with-listener:build
java -Dedc.fs.config=transfer/transfer-00-prerequisites/resources/configuration/consumer-configuration.properties -jar transfer/transfer-04-event-consumer/consumer-with-listener/build/libs/connector.jar

2. 协商新合同

参考官方文档

bash 复制代码
curl -d @transfer/transfer-01-negotiation/resources/negotiate-contract.json \
  -X POST -H 'content-type: application/json' http://localhost:29193/management/v3/contractnegotiations \
  -s | jq

3.获取合同协议id

参考官方文档

css 复制代码
curl -X GET "http://localhost:29193/management/v3/contractnegotiations/{{contract-negotiation-id}}" \
    --header 'Content-Type: application/json' \
    -s | jq

4. 执行文件传输

参考官方文档

启动 http 服务器

参考官方文档

作为先决条件,您需要有一个在端口 4000 上运行并记录所有传入请求的日志网络服务器,数据将被发送到该服务器。

vbscript 复制代码
docker build -t http-request-logger util/http-request-logger
docker run -p 4000:4000 http-request-logger

将请求主体contractId内的属性替换 为上一次调用中的合同协议 ID。然后运行:

arduino 复制代码
curl -X POST "http://localhost:29193/management/v3/transferprocesses" \
  -H "Content-Type: application/json" \
  -d @transfer/transfer-02-provider-push/resources/start-transfer.json \
  -s | jq

5.检查日志

参考官方文档

消费者应该输出类似如下的日志:

csharp 复制代码
INFO 2023-10-16T09:29:46.271592 TransferProcessStartedListener received STARTED event   <----------------------------

如果您看到TransferProcessStartedListener received STARTED event日志消息,则表示您的事件消费者已成功配置。

相关推荐
80530单词突击赢7 小时前
JavaWeb进阶:SpringBoot核心与Bean管理
java·spring boot·后端
爬山算法7 小时前
Hibernate(87)如何在安全测试中使用Hibernate?
java·后端·hibernate
WeiXiao_Hyy7 小时前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
苏渡苇7 小时前
优雅应对异常,从“try-catch堆砌”到“设计驱动”
java·后端·设计模式·学习方法·责任链模式
long3168 小时前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法
rannn_1118 小时前
【苍穹外卖|Day4】套餐页面开发(新增套餐、分页查询、删除套餐、修改套餐、起售停售)
java·spring boot·后端·学习
短剑重铸之日8 小时前
《设计模式》第十一篇:总结
java·后端·设计模式·总结
Dragon Wu9 小时前
Spring Security Oauth2.1 授权码模式实现前后端分离的方案
java·spring boot·后端·spring cloud·springboot·springcloud
一个有梦有戏的人10 小时前
Python3基础:进阶基础,筑牢编程底层能力
后端·python
爬山算法10 小时前
Hibernate(88)如何在负载测试中使用Hibernate?
java·后端·hibernate