001package com.github.theholywaffle.teamspeak3; 002 003/* 004 * #%L 005 * TeamSpeak 3 Java API 006 * %% 007 * Copyright (C) 2014 Bert De Geyter 008 * %% 009 * Permission is hereby granted, free of charge, to any person obtaining a copy 010 * of this software and associated documentation files (the "Software"), to deal 011 * in the Software without restriction, including without limitation the rights 012 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 013 * copies of the Software, and to permit persons to whom the Software is 014 * furnished to do so, subject to the following conditions: 015 * 016 * The above copyright notice and this permission notice shall be included in 017 * all copies or substantial portions of the Software. 018 * 019 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 020 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 021 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 022 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 023 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 024 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 025 * THE SOFTWARE. 026 * #L% 027 */ 028 029import com.github.theholywaffle.teamspeak3.commands.Command; 030 031public class SocketWriter extends Thread { 032 033 private final TS3Query ts3; 034 private final int floodRate; 035 private volatile long lastCommand = System.currentTimeMillis(); 036 037 public SocketWriter(TS3Query ts3, int floodRate) { 038 super("[TeamSpeak-3-Java-API] SocketWriter"); 039 this.ts3 = ts3; 040 if (floodRate > 50) { 041 this.floodRate = floodRate; 042 } else { 043 this.floodRate = 50; 044 } 045 } 046 047 @Override 048 public void run() { 049 while (ts3.getSocket() != null && ts3.getSocket().isConnected() 050 && ts3.getOut() != null && !isInterrupted()) { 051 final Command c = ts3.getCommandList().peek(); 052 if (c != null && !c.isSent()) { 053 final String msg = c.toString(); 054 TS3Query.log.info("> " + msg); 055 056 c.setSent(); 057 ts3.getOut().println(msg); 058 lastCommand = System.currentTimeMillis(); 059 } 060 try { 061 Thread.sleep(floodRate); 062 } catch (final InterruptedException e) { 063 interrupt(); 064 break; 065 } 066 } 067 068 if (!isInterrupted()) { 069 TS3Query.log.warning("SocketWriter has stopped!"); 070 } 071 } 072 073 public long getIdleTime() { 074 return System.currentTimeMillis() - lastCommand; 075 } 076 077}