]> git.basschouten.com Git - openhab-addons.git/blob
fdf5895fd8e98743c35bb9b525fd3999603225cf
[openhab-addons.git] /
1 /**
2  * Copyright (c) 2010-2023 Contributors to the openHAB project
3  *
4  * See the NOTICE file(s) distributed with this work for additional
5  * information.
6  *
7  * This program and the accompanying materials are made available under the
8  * terms of the Eclipse Public License 2.0 which is available at
9  * http://www.eclipse.org/legal/epl-2.0
10  *
11  * SPDX-License-Identifier: EPL-2.0
12  */
13 package org.openhab.binding.avmfritz.internal.hardware;
14
15 import org.eclipse.jdt.annotation.NonNullByDefault;
16 import org.eclipse.jetty.client.api.Response;
17 import org.eclipse.jetty.client.api.Response.CompleteListener;
18 import org.eclipse.jetty.client.api.Response.ContentListener;
19 import org.eclipse.jetty.client.api.Response.FailureListener;
20 import org.eclipse.jetty.client.api.Response.SuccessListener;
21 import org.eclipse.jetty.client.api.Result;
22 import org.eclipse.jetty.client.util.BufferingResponseListener;
23 import org.openhab.binding.avmfritz.internal.hardware.callbacks.FritzAhaCallback;
24 import org.slf4j.Logger;
25 import org.slf4j.LoggerFactory;
26
27 /**
28  * Implementation of Jetty ContextExchange to handle callbacks
29  *
30  * @author Robert Bausdorf - Initial contribution
31  */
32 @NonNullByDefault
33 public class FritzAhaContentExchange extends BufferingResponseListener
34         implements SuccessListener, FailureListener, ContentListener, CompleteListener {
35
36     private final Logger logger = LoggerFactory.getLogger(FritzAhaContentExchange.class);
37
38     /**
39      * Callback to execute on complete response
40      */
41     private final FritzAhaCallback callback;
42
43     /**
44      * Constructor
45      *
46      * @param callback Callback which execute method has to be called.
47      */
48     public FritzAhaContentExchange(FritzAhaCallback callback) {
49         this.callback = callback;
50     }
51
52     @Override
53     public void onSuccess(@NonNullByDefault({}) Response response) {
54         logger.debug("{} response: {}", response.getRequest().getScheme().toUpperCase(), response.getStatus());
55     }
56
57     @Override
58     public void onFailure(@NonNullByDefault({}) Response response, @NonNullByDefault({}) Throwable failure) {
59         logger.debug("{} response failed: {}", response.getRequest().getMethod(), failure.getLocalizedMessage(),
60                 failure);
61     }
62
63     @Override
64     public void onComplete(@NonNullByDefault({}) Result result) {
65         String content = getContentAsString();
66         logger.debug("{} response complete: {}", result.getRequest().getMethod(), content);
67         callback.execute(result.getResponse().getStatus(), content);
68     }
69 }