forked from TheHolyWaffle/TeamSpeak-3-Java-API
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTS3Query.java
199 lines (171 loc) · 4.72 KB
/
TS3Query.java
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
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
/*******************************************************************************
* Copyright (c) 2014 Bert De Geyter (https://github.com/TheHolyWaffle).
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the GNU Public License v3.0
* which accompanies this distribution, and is available at
* http://www.gnu.org/licenses/gpl.html
*
* Contributors:
* Bert De Geyter (https://github.com/TheHolyWaffle)
******************************************************************************/
package com.github.theholywaffle.teamspeak3;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.Socket;
import java.util.concurrent.ConcurrentLinkedQueue;
import java.util.logging.Handler;
import java.util.logging.Logger;
import com.github.theholywaffle.teamspeak3.api.Callback;
import com.github.theholywaffle.teamspeak3.api.exception.TS3CommandFailedException;
import com.github.theholywaffle.teamspeak3.api.exception.TS3ConnectionFailedException;
import com.github.theholywaffle.teamspeak3.commands.Command;
import com.github.theholywaffle.teamspeak3.log.LogHandler;
public class TS3Query {
private Socket socket;
private PrintWriter out;
private BufferedReader in;
private SocketReader socketReader;
private SocketWriter socketWriter;
private KeepAliveThread keepAlive;
private ConcurrentLinkedQueue<Command> commandList = new ConcurrentLinkedQueue<>();
private EventManager eventManager = new EventManager();
private TS3Api api;
private TS3Config config;
public static final Logger log = Logger.getLogger(TS3Query.class.getName());
public enum FloodRate {
DEFAULT(350),
UNLIMITED(0);
private int ms;
FloodRate(int ms) {
this.ms = ms;
}
public int getMs() {
return ms;
}
}
public TS3Query(TS3Config config) {
log.setUseParentHandlers(false);
log.addHandler(new LogHandler(config.getDebugToFile()));
log.setLevel(config.getDebugLevel());
this.config = config;
}
public TS3Query connect() {
// exit();
try {
socket = new Socket(config.getHost(), config.getQueryPort());
if (socket.isConnected()) {
out = new PrintWriter(socket.getOutputStream(), true);
in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
socketReader = new SocketReader(this);
socketReader.start();
socketWriter = new SocketWriter(this, config.getFloodRate().getMs());
socketWriter.start();
keepAlive = new KeepAliveThread(this, socketWriter);
keepAlive.start();
}
} catch (IOException e) {
throw new TS3ConnectionFailedException(e);
}
// Executing config object
TS3Api api = getApi();
if (config.getUsername() != null && config.getPassword() != null) {
api.login(config.getUsername(), config.getPassword());
}
return this;
}
public Socket getSocket() {
return socket;
}
public PrintWriter getOut() {
return out;
}
public BufferedReader getIn() {
return in;
}
public boolean doCommand(Command c) {
commandList.offer(c);
long start = System.currentTimeMillis();
while (!c.isAnswered() && System.currentTimeMillis() - start < 4_000) {
try {
Thread.sleep(50);
} catch (InterruptedException e) {
throw new TS3CommandFailedException(e);
}
}
if (!c.isAnswered()) {
log.severe(("Command " + c.getName() + " is not answered in time."));
commandList.remove(c);
return false;
}
return true;
}
public void doCommandAsync(final Command c) {
doCommandAsync(c, null);
}
public void doCommandAsync(final Command c, final Callback callback) {
new Thread(new Runnable() {
@Override
public void run() {
doCommand(c);
if (callback != null) {
callback.handle();
}
}
}).start();
}
/**
* Removes and closes all used resources to the teamspeak server.
*/
public void exit() {
if (out != null) {
out.close();
}
if (in != null) {
try {
in.close();
} catch (IOException ignored) {
}
}
if (socket != null) {
try {
socket.close();
} catch (IOException ignored) {
}
}
try {
if (socketReader != null) {
socketReader.finish();
socketReader.join();
}
if (socketWriter != null) {
socketWriter.finish();
socketWriter.join();
}
if (keepAlive != null) {
keepAlive.finish();
keepAlive.join();
}
} catch (InterruptedException e) {
e.printStackTrace();
}
commandList.clear();
commandList = null;
for (Handler lh : log.getHandlers()) {
log.removeHandler(lh);
}
}
public ConcurrentLinkedQueue<Command> getCommandList() {
return commandList;
}
public EventManager getEventManager() {
return eventManager;
}
public TS3Api getApi() {
if (api == null) {
api = new TS3Api(this);
}
return api;
}
}