v0.3
Now logging own messages.
This commit is contained in:
parent
82d35a3a1f
commit
0093fe84d3
9 changed files with 58 additions and 32 deletions
2
pom.xml
2
pom.xml
|
@ -4,7 +4,7 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>loper</groupId>
|
<groupId>loper</groupId>
|
||||||
<artifactId>InnaIrcBot</artifactId>
|
<artifactId>InnaIrcBot</artifactId>
|
||||||
<version>0.2.2-SNAPSHOT</version>
|
<version>0.3-SNAPSHOT</version>
|
||||||
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
<name>InnaIrcBot</name>
|
<name>InnaIrcBot</name>
|
||||||
|
|
|
@ -1,14 +1,14 @@
|
||||||
/**
|
/**
|
||||||
* InnaIrcBot
|
* InnaIrcBot
|
||||||
* @author Dmitry Isaenko
|
* @author Dmitry Isaenko
|
||||||
* Russia, 2018.
|
* Russia, 2018-2019.
|
||||||
* */
|
* */
|
||||||
package InnaIrcBot;
|
package InnaIrcBot;
|
||||||
|
|
||||||
import InnaIrcBot.Config.StorageReader;
|
import InnaIrcBot.Config.StorageReader;
|
||||||
|
|
||||||
public class BotStart {
|
public class BotStart {
|
||||||
//TODO: Steam link, flood control, kikbana
|
//TODO: flood control
|
||||||
//TODO: setDaemon(true)
|
//TODO: setDaemon(true)
|
||||||
//TODO: multiple connections to one server not allowed
|
//TODO: multiple connections to one server not allowed
|
||||||
|
|
||||||
|
|
|
@ -22,6 +22,9 @@ public class PrivateMsgCommander { // T
|
||||||
if (administrators.contains(sender) && !message.isEmpty()) {
|
if (administrators.contains(sender) && !message.isEmpty()) {
|
||||||
String[] cmd = message.split("(\\s)|(\t)+?", 2);
|
String[] cmd = message.split("(\\s)|(\t)+?", 2);
|
||||||
cmd[0] = cmd[0].toLowerCase();
|
cmd[0] = cmd[0].toLowerCase();
|
||||||
|
if (cmd.length > 1)
|
||||||
|
cmd[1] = cmd[1].trim();
|
||||||
|
|
||||||
|
|
||||||
switch (cmd[0]){
|
switch (cmd[0]){
|
||||||
case "tell":
|
case "tell":
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
package InnaIrcBot;
|
package InnaIrcBot;
|
||||||
|
|
||||||
public class GlobalData {
|
public class GlobalData {
|
||||||
public static final String version = "InnaIrcBot v0.2.2 \"Маньчжурия\"";
|
private static final String version = "InnaIrcBot v0.3 \"Карелия\"";
|
||||||
public static synchronized String getAppVersion(){
|
public static synchronized String getAppVersion(){
|
||||||
return version;
|
return version;
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,8 +6,9 @@ public class BotDriver {
|
||||||
private static HashMap<String, String[][]> serverDriver = new HashMap<>();
|
private static HashMap<String, String[][]> serverDriver = new HashMap<>();
|
||||||
/**
|
/**
|
||||||
* Define driver for desired server
|
* Define driver for desired server
|
||||||
* */ // TODO: add proxy worker for using with multiple drivers
|
* */
|
||||||
public static synchronized boolean setFileDriver(String serverName, String driver, String[] driverParams){
|
// TODO: add proxy worker for using with multiple drivers
|
||||||
|
public static synchronized boolean setLogDriver(String serverName, String driver, String[] driverParams){
|
||||||
if (!driver.isEmpty() && driverParams != null && driverParams.length > 0 && driverParams[0] != null && !driverParams[0].isEmpty()) {
|
if (!driver.isEmpty() && driverParams != null && driverParams.length > 0 && driverParams[0] != null && !driverParams[0].isEmpty()) {
|
||||||
String[][] drvAndParams = {
|
String[][] drvAndParams = {
|
||||||
{driver},
|
{driver},
|
||||||
|
@ -29,7 +30,9 @@ public class BotDriver {
|
||||||
case "Zero":
|
case "Zero":
|
||||||
return new BotZeroWorker();
|
return new BotZeroWorker();
|
||||||
default:
|
default:
|
||||||
System.out.println("Configuration issue: BotDriver->getWorker() can't find required driver \""+serverDriver.get(serverName)[0][0]+"\".Using \"ZeroWorker\".");
|
System.out.println("Configuration issue: BotDriver->getWorker() can't find required driver \""
|
||||||
|
+serverDriver.get(serverName)[0][0]
|
||||||
|
+"\".Using \"ZeroWorker\".");
|
||||||
return new BotZeroWorker();
|
return new BotZeroWorker();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,7 +51,6 @@ public class DataProvider implements Runnable {
|
||||||
this.ableToRun = false;
|
this.ableToRun = false;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
InputStream inStream = socket.getInputStream();
|
InputStream inStream = socket.getInputStream();
|
||||||
InputStreamReader isr = new InputStreamReader(inStream, StandardCharsets.UTF_8); //TODO set charset in options;
|
InputStreamReader isr = new InputStreamReader(inStream, StandardCharsets.UTF_8); //TODO set charset in options;
|
||||||
this.rawStreamReader = new BufferedReader(isr);
|
this.rawStreamReader = new BufferedReader(isr);
|
||||||
|
@ -69,18 +68,8 @@ public class DataProvider implements Runnable {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void run(){
|
public void run(){
|
||||||
if (!ableToRun) {
|
if (!ableToRun || !this.initConnection(rawStreamReader)
|
||||||
this.close();
|
|| !BotDriver.setLogDriver(serverName, configFile.getLogDriver(), configFile.getLogDriverParameters())) { //Prepare logDriver for using in threads.
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(!this.initConnection(rawStreamReader)) {
|
|
||||||
this.close();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
//Prepare logDriver for using in threads.
|
|
||||||
if(!BotDriver.setFileDriver(serverName, configFile.getLogDriver(), configFile.getLogDriverParameters())) {
|
|
||||||
this.close();
|
this.close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -95,9 +84,13 @@ public class DataProvider implements Runnable {
|
||||||
new PipedInputStream(streamOut), StandardCharsets.UTF_8)
|
new PipedInputStream(streamOut), StandardCharsets.UTF_8)
|
||||||
);
|
);
|
||||||
|
|
||||||
Runnable consumer = new SystemConsumer(streamBufferedReader, userNick, channelsMap, this.configFile);
|
Runnable systemConsumer = new SystemConsumer(streamBufferedReader, userNick, channelsMap, this.configFile);
|
||||||
new Thread(consumer).start();
|
new Thread(systemConsumer).start();
|
||||||
channelsMap.put("", new PrintWriter(streamOut)); // Not sure that PrintWriter is thread-safe..
|
PrintWriter systemConsumerWriter = new PrintWriter(streamOut);
|
||||||
|
|
||||||
|
StreamProvider.setSysConsumer(serverName, systemConsumerWriter); // Register system consumer at StreamProvider
|
||||||
|
|
||||||
|
channelsMap.put("", systemConsumerWriter); // Not sure that PrintWriter is thread-safe..
|
||||||
} catch (IOException e){
|
} catch (IOException e){
|
||||||
System.out.println("Internal issue: DataProvider->run() I/O exception while initialized child objects.\n\t"+e); // caused by Socket
|
System.out.println("Internal issue: DataProvider->run() I/O exception while initialized child objects.\n\t"+e); // caused by Socket
|
||||||
this.close();
|
this.close();
|
||||||
|
|
|
@ -2,18 +2,26 @@ package InnaIrcBot.ProvidersConsumers;
|
||||||
|
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
import java.io.OutputStreamWriter;
|
import java.io.OutputStreamWriter;
|
||||||
|
import java.io.PrintWriter;
|
||||||
import java.net.Socket;
|
import java.net.Socket;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
public class StreamProvider {
|
public class StreamProvider {
|
||||||
|
|
||||||
private static HashMap<String, OutputStreamWriter> srvStreamMap = new HashMap<>();
|
private static HashMap<String, OutputStreamWriter> srvStreamMap = new HashMap<>();
|
||||||
//private static OutputStreamWriter streamWriter;
|
private static HashMap<String, PrintWriter> srvSysConsumersMap = new HashMap<>();
|
||||||
|
|
||||||
public static synchronized void writeToStream(String server, String message){
|
public static synchronized void writeToStream(String server, String message){
|
||||||
try {
|
try {
|
||||||
srvStreamMap.get(server).write(message+"\n");
|
srvStreamMap.get(server).write(message+"\n");
|
||||||
srvStreamMap.get(server).flush();
|
srvStreamMap.get(server).flush();
|
||||||
|
|
||||||
|
//System.out.println(message);
|
||||||
|
// If this application says something, then pass it into system consumer thread to handle
|
||||||
|
if (message.startsWith("PRIVMSG")) {
|
||||||
|
srvSysConsumersMap.get(server).println("INNA "+message);
|
||||||
|
srvSysConsumersMap.get(server).flush();
|
||||||
|
}
|
||||||
} catch (java.io.IOException e){
|
} catch (java.io.IOException e){
|
||||||
System.out.println("Internal issue: StreamProvider->writeToStream() caused I/O exception.");
|
System.out.println("Internal issue: StreamProvider->writeToStream() caused I/O exception.");
|
||||||
}
|
}
|
||||||
|
@ -30,5 +38,10 @@ public class StreamProvider {
|
||||||
}
|
}
|
||||||
public static synchronized void delStream(String server){
|
public static synchronized void delStream(String server){
|
||||||
srvStreamMap.remove(server);
|
srvStreamMap.remove(server);
|
||||||
|
srvSysConsumersMap.remove(server);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static synchronized void setSysConsumer(String server, PrintWriter pw){
|
||||||
|
srvSysConsumersMap.put(server, pw);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,6 @@ import java.time.format.DateTimeFormatter;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.concurrent.atomic.AtomicBoolean;
|
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
public class SystemConsumer implements Runnable{
|
public class SystemConsumer implements Runnable{
|
||||||
|
@ -73,7 +72,7 @@ public class SystemConsumer implements Runnable{
|
||||||
|
|
||||||
if (proxyRequired)
|
if (proxyRequired)
|
||||||
if (getProxy(dataStrings[0], dataStrings[1], dataStrings[2]))
|
if (getProxy(dataStrings[0], dataStrings[1], dataStrings[2]))
|
||||||
continue;
|
continue; // TODO: check this. Continue is fair?
|
||||||
|
|
||||||
if (dataStrings[0].equals("PRIVMSG") && dataStrings[2].indexOf("\u0001") < dataStrings[2].lastIndexOf("\u0001"))
|
if (dataStrings[0].equals("PRIVMSG") && dataStrings[2].indexOf("\u0001") < dataStrings[2].lastIndexOf("\u0001"))
|
||||||
replyCTCP(dataStrings[1], dataStrings[2].substring(dataStrings[2].indexOf(":")+1));
|
replyCTCP(dataStrings[1], dataStrings[2].substring(dataStrings[2].indexOf(":")+1));
|
||||||
|
@ -84,12 +83,22 @@ public class SystemConsumer implements Runnable{
|
||||||
commander.receiver(dataStrings[1], dataStrings[2].replaceAll("^.+?:", "").trim());
|
commander.receiver(dataStrings[1], dataStrings[2].replaceAll("^.+?:", "").trim());
|
||||||
writerWorker.logAdd("[system]", "PRIVMSG sent to", "commander");
|
writerWorker.logAdd("[system]", "PRIVMSG sent to", "commander");
|
||||||
}
|
}
|
||||||
|
else if (dataStrings[0].equals("INNA")) {
|
||||||
|
String[] splitter;
|
||||||
|
if (dataStrings.length > 2){ // Don't touch 'cuz it's important
|
||||||
|
splitter = dataStrings[2].split(" ", 2);
|
||||||
|
if (splitter.length == 2){
|
||||||
|
handleSpecial(dataStrings[1], splitter[0], splitter[1]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
writerWorker.logAdd(dataStrings[0], dataStrings[1], dataStrings[2]); // TODO: Track users
|
writerWorker.logAdd(dataStrings[0], dataStrings[1], dataStrings[2]); // TODO: Track users
|
||||||
//System.out.println("System: "+"|"+dataStrings[0]+"|"+dataStrings[1]+"|"+dataStrings[2]+"|");
|
//System.out.println("System: "+"|"+dataStrings[0]+"|"+dataStrings[1]+"|"+dataStrings[2]+"|");
|
||||||
}
|
}
|
||||||
} catch (java.io.IOException e){
|
} catch (java.io.IOException e){
|
||||||
System.out.println("Internal issue: thread SystemConsumer->run() caused I/O exception."); // TODO: reconnect
|
System.out.println("Internal issue: thread SystemConsumer->run() caused I/O exception."); // TODO: reconnect OR AT LEAST DIE
|
||||||
|
StreamProvider.writeToStream(serverName, "QUIT :Internal issue: thread ChanConsumer->run() caused I/O exception");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
private boolean getProxy(String eventNum, String sender, String message){ //TODO: if can't join: like channel with password
|
private boolean getProxy(String eventNum, String sender, String message){ //TODO: if can't join: like channel with password
|
||||||
|
@ -138,8 +147,16 @@ public class SystemConsumer implements Runnable{
|
||||||
}
|
}
|
||||||
private String simplifyNick(String nick){ return nick.replaceAll("!.*$",""); }
|
private String simplifyNick(String nick){ return nick.replaceAll("!.*$",""); }
|
||||||
|
|
||||||
//todo: nandle nickserv messages
|
|
||||||
|
|
||||||
|
private void handleSpecial(String event, String chanel, String message){
|
||||||
|
//System.out.println("|"+event+"|"+chanel+"|"+message+"|");
|
||||||
|
if (channelsMap.containsKey(chanel)){
|
||||||
|
channelsMap.get(chanel).println(event+" "+nick+" "+chanel+" "+message); // WTF ><
|
||||||
|
channelsMap.get(chanel).flush();
|
||||||
|
//System.out.println("Formatted: |"+event+"|"+nick+"|"+chanel+" "+message+"|");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//todo: nandle nickserv messages
|
||||||
private void handleNumeric(String eventNum, String sender, String message){
|
private void handleNumeric(String eventNum, String sender, String message){
|
||||||
switch (eventNum){
|
switch (eventNum){
|
||||||
case "433": // TODO: try to use alternative nickname
|
case "433": // TODO: try to use alternative nickname
|
||||||
|
@ -165,7 +182,6 @@ public class SystemConsumer implements Runnable{
|
||||||
ChanConsumer consumer = new ChanConsumer(streamBufferedReader, storageFile.getServerName(), chan, nick, usersOnChanArr, storageFile.getRejoinOnKick(), channelsMap, storageFile.getChanelConfigurationsPath());
|
ChanConsumer consumer = new ChanConsumer(streamBufferedReader, storageFile.getServerName(), chan, nick, usersOnChanArr, storageFile.getRejoinOnKick(), channelsMap, storageFile.getChanelConfigurationsPath());
|
||||||
new Thread(consumer).start();
|
new Thread(consumer).start();
|
||||||
|
|
||||||
|
|
||||||
for (String msgStored : proxyAList.get(chan)) {
|
for (String msgStored : proxyAList.get(chan)) {
|
||||||
channelsMap.get(chan).println(msgStored);
|
channelsMap.get(chan).println(msgStored);
|
||||||
channelsMap.get(chan).flush();
|
channelsMap.get(chan).flush();
|
||||||
|
@ -185,9 +201,7 @@ public class SystemConsumer implements Runnable{
|
||||||
break;
|
break;
|
||||||
case "NICK":
|
case "NICK":
|
||||||
if (sender.startsWith(nick+"!")) {
|
if (sender.startsWith(nick+"!")) {
|
||||||
String oldNick = nick;
|
|
||||||
nick = message.trim();
|
nick = message.trim();
|
||||||
|
|
||||||
writerWorker.logAdd("[system]", "catch/handled own NICK change from:", sender+" to: "+message);
|
writerWorker.logAdd("[system]", "catch/handled own NICK change from:", sender+" to: "+message);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -6,7 +6,7 @@ import InnaIrcBot.LogDriver.Worker;
|
||||||
public class DriverTest {
|
public class DriverTest {
|
||||||
|
|
||||||
public static void main(String[] args){
|
public static void main(String[] args){
|
||||||
if (BotDriver.setFileDriver("irc.tomsk.net", "SQLiteDriver", new String[]{"/tmp/"}))
|
if (BotDriver.setLogDriver("irc.tomsk.net", "SQLiteDriver", new String[]{"/tmp/"}))
|
||||||
System.out.println("Successful driver initiation");
|
System.out.println("Successful driver initiation");
|
||||||
else {
|
else {
|
||||||
System.out.println("Failed driver initiation");
|
System.out.println("Failed driver initiation");
|
||||||
|
|
Loading…
Reference in a new issue