LiteLoaderLogUpload.java
3.81 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
/*
* This file is part of LiteLoader.
* Copyright (C) 2012-16 Adam Mummery-Smith
* All Rights Reserved.
*/
package com.mumfrey.liteloader.util.net;
import java.io.BufferedReader;
import java.io.DataOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.net.HttpURLConnection;
import java.net.URL;
import java.net.URLEncoder;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import com.mumfrey.liteloader.core.LiteLoader;
import com.mumfrey.liteloader.util.log.LiteLoaderLogger;
/**
* Upload manager for posting logs to liteloader.com
*
* @author Adam Mummery-Smith
*/
public class LiteLoaderLogUpload extends Thread
{
private static final String POST_URL = "http://logs.liteloader.com/post";
private static final String LITELOADER_KEY = "liteloader0cea4593b6a51e7c";
private final String encodedData;
private volatile boolean completed;
private String response = "Unknown Error";
public LiteLoaderLogUpload(String nick, String uuid, String content)
{
Map<String, String> data = new HashMap<String, String>();
data.put("nick", nick);
data.put("uuid", uuid);
data.put("token", LITELOADER_KEY);
data.put("version", LiteLoader.getVersion());
data.put("brand", "" + LiteLoader.getBranding());
data.put("log", content);
StringBuilder sb = new StringBuilder();
try
{
String separator = "";
for (Entry<String, String> postValue : data.entrySet())
{
sb.append(separator).append(postValue.getKey()).append("=").append(URLEncoder.encode(postValue.getValue(), "UTF-8"));
separator = "&";
}
}
catch (UnsupportedEncodingException ex)
{
ex.printStackTrace();
}
this.encodedData = sb.toString();
}
public boolean isCompleted()
{
return this.completed;
}
public String getLogUrl()
{
return this.response;
}
@Override
public void run()
{
try
{
URL url = new URL(POST_URL);
HttpURLConnection httpClient = (HttpURLConnection)url.openConnection();
httpClient.setConnectTimeout(5000);
httpClient.setReadTimeout(10000);
httpClient.addRequestProperty("Content-type", "application/x-www-form-urlencoded");
httpClient.addRequestProperty("User-Agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)"); // For not fail++
httpClient.setRequestMethod("POST");
httpClient.setDoOutput(true);
DataOutputStream outputStream = new DataOutputStream(httpClient.getOutputStream());
outputStream.writeBytes(this.encodedData);
outputStream.flush();
InputStream httpStream = httpClient.getInputStream();
try
{
StringBuilder readString = new StringBuilder();
BufferedReader reader = new BufferedReader(new InputStreamReader(httpStream));
String readLine;
while ((readLine = reader.readLine()) != null)
{
readString.append(readLine).append("\n");
}
reader.close();
this.response = readString.toString();
}
catch (IOException ex)
{
ex.printStackTrace();
}
httpStream.close();
outputStream.close();
}
catch (Exception ex)
{
this.response = ex.getMessage();
LiteLoaderLogger.warning("Error posting log to liteloader.com: %s: %s", ex.getClass(), ex.getMessage());
}
this.completed = true;
}
}