对于我正在构建的应用程序,我需要能够发送指示处理文件的进度和成功/失败的 slack 消息。
我没有找到一种完全直接的方法,所以我正在做以下事情:
声明一个队列通道来接收需要发送的消息
@Bean
MessageChannel slackChannel() {
return MessageChannels.queue(SLACK_CHANNEL).get();
}
发送到该频道的每条消息都将作为 Slack 消息发送。为了在那里推送消息,我正在做一个像:
@Bean
IntegrationFlow startFlow() {
return IntegrationFlows
...
.wireTap(sendSlack("A nice message describing what's happening")
...
}
private IntegrationFlow sendSlack(String message) {
return sf -> sf
.transform(Message.class, m -> MessageBuilder.createMessage(message, m.getHeaders()))
.channel(SLACK_CHANNEL);
}
最后,松弛流:
@Bean
IntegrationFlow slackFlow() {
return IntegrationFlows.from(SLACK_CHANNEL)
.handle(slackService, "send")
.get();
}
SlackService
类具有发送消息的所有逻辑。我喜欢这种方法,因为我可以从不同的地方向 slack 通道发送消息并以相同的方式进行处理,但我不确定让私有方法 sendSlack
返回一个 IntegrationFlow 并且还具有订阅频道的 bean。简化为更好吗?
private IntegrationFlow sendSlack(String message) {
return sf -> sf
.transform(Message.class, m -> MessageBuilder.createMessage(message, m.getHeaders()))
.handle(slackService, "send");
}
我不需要带有此选项的队列通道,但我不确定是否正确使用了 wireTap。
答案 0 :(得分:0)
我想说这不是设计时使用窃听器的方式。查看文档: https://www.enterpriseintegrationpatterns.com/patterns/messaging/WireTap.html
<块引用>您如何检查在点对点通道上传输的消息?
根据您当前的配置,您只需忽略发布到该窃听器的原始消息,而是创建自己的作为该 sendSlack()
工厂方法的参数。其中,本质上只是一个静态值,因此仅仅为了发送一个静态字符串而拥有如此复杂的分布式逻辑是没有意义的。 (此时我可能错了,您向 slack 发送的信息不像问题中的代码片段那样静态......)
您可以考虑使用 @MessagingGateway
作为合约来区分和隧道化业务逻辑:https://docs.spring.io/spring-integration/docs/current/reference/html/messaging-endpoints.html#gateway