Clean up imports
[rhynodge.git] / src / main / java / net / pterodactylus / rhynodge / queries / HttpQuery.java
1 /*
2  * Rhynodge - HttpQuery.java - Copyright © 2013 David Roden
3  *
4  * This program is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
16  */
17
18 package net.pterodactylus.rhynodge.queries;
19
20 import java.io.IOException;
21 import java.util.concurrent.TimeUnit;
22
23 import net.pterodactylus.rhynodge.Query;
24 import net.pterodactylus.rhynodge.State;
25 import net.pterodactylus.rhynodge.states.FailedState;
26 import net.pterodactylus.rhynodge.states.HttpState;
27
28 import org.apache.http.HttpEntity;
29 import org.apache.http.HttpResponse;
30 import org.apache.http.HttpStatus;
31 import org.apache.http.client.HttpClient;
32 import org.apache.http.client.methods.HttpGet;
33 import org.apache.http.client.protocol.ResponseContentEncoding;
34 import org.apache.http.impl.client.HttpClientBuilder;
35 import org.apache.http.params.HttpConnectionParams;
36 import org.apache.http.util.EntityUtils;
37
38 /**
39  * {@link Query} that performs an HTTP GET request to a fixed uri.
40  *
41  * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
42  */
43 public class HttpQuery implements Query {
44
45         /** The uri to request. */
46         private final String uri;
47
48         /**
49          * Creates a new HTTP query.
50          *
51          * @param uri
52          *            The uri to request
53          */
54         public HttpQuery(String uri) {
55                 this.uri = uri;
56         }
57
58         //
59         // QUERY METHODS
60         //
61
62         /**
63          * {@inheritDoc}
64          */
65         @Override
66         @SuppressWarnings("deprecation")
67         public State state() {
68                 HttpClient httpClient = HttpClientBuilder.create()
69                                 .setSSLHostnameVerifier((hostname, session) -> true)
70                                 .addInterceptorFirst(new ResponseContentEncoding()).build();
71                 HttpGet get = new HttpGet(uri);
72
73                 try {
74                         /* make request. */
75                         get.addHeader("User-Agent", "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/536.11 (KHTML, like Gecko) Ubuntu/12.04 Chromium/20.0.1132.47 Chrome/20.0.1132.47 Safari/536.11");
76                         HttpConnectionParams.setConnectionTimeout(get.getParams(), (int) TimeUnit.SECONDS.toMillis(300));
77                         HttpConnectionParams.setSoTimeout(get.getParams(), (int) TimeUnit.SECONDS.toMillis(300));
78                         HttpResponse response = httpClient.execute(get);
79                         if (response.getStatusLine().getStatusCode() != HttpStatus.SC_OK) {
80                                 return new FailedState(new IllegalStateException(String.format("Invalid HTTP Status: %d", response.getStatusLine().getStatusCode())));
81                         }
82                         HttpEntity entity = response.getEntity();
83
84                         /* yay, done! */
85                         return new HttpState(uri, response.getStatusLine().getStatusCode(), entity.getContentType().getValue(), EntityUtils.toByteArray(entity));
86
87                 } catch (IOException ioe1) {
88                         return new FailedState(ioe1);
89                 }
90         }
91
92 }