From 80b6cbfc9c861469146318d0b3dd5f8b8b525b8a Mon Sep 17 00:00:00 2001 From: xiejun <xiejun@vci-tech.com> Date: 星期五, 01 十一月 2024 15:11:19 +0800 Subject: [PATCH] Revert "集成获取mdm分发通用数据格式接口集成" --- Source/BladeX-Tool/blade-starter-http/src/main/java/org/springblade/core/http/AsyncCall.java | 76 ++++++++++++++++++++++++++++++++++++++ 1 files changed, 76 insertions(+), 0 deletions(-) diff --git a/Source/BladeX-Tool/blade-starter-http/src/main/java/org/springblade/core/http/AsyncCall.java b/Source/BladeX-Tool/blade-starter-http/src/main/java/org/springblade/core/http/AsyncCall.java new file mode 100644 index 0000000..4cb79e9 --- /dev/null +++ b/Source/BladeX-Tool/blade-starter-http/src/main/java/org/springblade/core/http/AsyncCall.java @@ -0,0 +1,76 @@ +/* + * Copyright (c) 2018-2028, DreamLu All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * + * Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * Neither the name of the dreamlu.net developer nor the names of its + * contributors may be used to endorse or promote products derived from + * this software without specific prior written permission. + * Author: DreamLu 鍗㈡槬姊� (596392912@qq.com) + */ +package org.springblade.core.http; + +import okhttp3.Call; +import okhttp3.Request; + +import java.io.IOException; +import java.util.function.BiConsumer; +import java.util.function.Consumer; + +/** + * 寮傛鎵ц鍣� + * + * @author L.cm + */ +public class AsyncCall { + private final static Consumer<ResponseSpec> DEFAULT_CONSUMER = (r) -> {}; + private final static BiConsumer<Request, IOException> DEFAULT_FAIL_CONSUMER = (r, e) -> {}; + private final Call call; + private Consumer<ResponseSpec> successConsumer; + private Consumer<ResponseSpec> responseConsumer; + private BiConsumer<Request, IOException> failedBiConsumer; + + AsyncCall(Call call) { + this.call = call; + this.successConsumer = DEFAULT_CONSUMER; + this.responseConsumer = DEFAULT_CONSUMER; + this.failedBiConsumer = DEFAULT_FAIL_CONSUMER; + } + + public void onSuccessful(Consumer<ResponseSpec> consumer) { + this.successConsumer = consumer; + this.execute(); + } + + public void onResponse(Consumer<ResponseSpec> consumer) { + this.responseConsumer = consumer; + this.execute(); + } + + public AsyncCall onFailed(BiConsumer<Request, IOException> biConsumer) { + this.failedBiConsumer = biConsumer; + return this; + } + + private void execute() { + call.enqueue(new AsyncCallback(this)); + } + + void onResponse(HttpResponse httpResponse) { + responseConsumer.accept(httpResponse); + } + + void onSuccessful(HttpResponse httpResponse) { + successConsumer.accept(httpResponse); + } + + void onFailure(Request request, IOException e) { + failedBiConsumer.accept(request, e); + } +} -- Gitblit v1.9.3