package com.planet_ink.coffee_mud.application;
import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.Socket;
import java.util.List;
import java.util.Map;
import java.util.Vector;
import com.planet_ink.coffee_mud.Commands.Shell;
import com.planet_ink.coffee_mud.Common.FakeSession;
import com.planet_ink.coffee_mud.Common.interfaces.PlayerAccount;
import com.planet_ink.coffee_mud.Common.interfaces.Session;
import com.planet_ink.coffee_mud.Common.interfaces.Session.InputCallback;
import com.planet_ink.coffee_mud.Common.interfaces.Session.SessionFilter;
import com.planet_ink.coffee_mud.Common.interfaces.Session.SessionStatus;
import com.planet_ink.coffee_mud.Libraries.Clans;
import com.planet_ink.coffee_mud.Libraries.interfaces.ColorLibrary;
import com.planet_ink.coffee_mud.Libraries.interfaces.DatabaseEngine;
import com.planet_ink.coffee_mud.Libraries.interfaces.ColorLibrary.ColorState;
import com.planet_ink.coffee_mud.MOBS.StdMOB;
import com.planet_ink.coffee_mud.MOBS.interfaces.MOB;
import com.planet_ink.coffee_mud.core.CMClass;
import com.planet_ink.coffee_mud.core.CMClass.CMObjectType;
import com.planet_ink.coffee_mud.core.CMFile;
import com.planet_ink.coffee_mud.core.CMLib;
import com.planet_ink.coffee_mud.core.CMParms;
import com.planet_ink.coffee_mud.core.CMProps;
import com.planet_ink.coffee_mud.core.CMSecurity;
import com.planet_ink.coffee_mud.core.CMStrings;
import com.planet_ink.coffee_mud.core.Log;
import com.planet_ink.coffee_mud.core.Resources;
import com.planet_ink.coffee_mud.core.database.DBConnection;
import com.planet_ink.coffee_mud.core.database.DBConnector;
import com.planet_ink.coffee_mud.core.database.DBInterface;
import com.planet_ink.coffee_mud.core.interfaces.CMObject;
import com.planet_ink.coffee_mud.core.interfaces.Environmental;
import com.planet_ink.coffee_mud.core.interfaces.MudHost;
import com.planet_ink.coffee_mud.core.interfaces.Physical;
import com.planet_ink.coffee_mud.core.interfaces.Tickable;
/*
Copyright 2007-2019 Bo Zimmerman
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
public class VFShell
{
public static void main(final String[] args)
{
final ThreadGroup g=new ThreadGroup("0");
final Thread t=new Thread(g,new Runnable()
{
@Override
public void run()
{
CMProps page=null;
CMLib.initialize(); // forces this thread to HAVE a library
Log.instance().configureLogFile(null,1);
Log.instance().configureLog(Log.Type.info, "ON");
Log.instance().configureLog(Log.Type.error, "ON");
Log.instance().configureLog(Log.Type.warning, "ON");
Log.instance().configureLog(Log.Type.debug, "ON");
Log.instance().configureLog(Log.Type.help, "ON");
Log.instance().configureLog(Log.Type.kills, "ON");
Log.instance().configureLog(Log.Type.combat, "ON");
Log.instance().configureLog(Log.Type.access, "ON");
String nameID="";
String iniFile="coffeemud.ini";
if(args.length>0)
{
for (final String element : args)
nameID+=" "+element;
nameID=nameID.trim();
final List<String> V=CMParms.cleanParameterList(nameID);
for(int v=0;v<V.size();v++)
{
final String s=V.get(v);
if(s.toUpperCase().startsWith("BOOT=")&&(s.length()>5))
{
iniFile=s.substring(5);
V.remove(v);
v--;
}
}
}
page=CMProps.loadPropPage(iniFile);
if ((page==null)||(!page.isLoaded()))
{
System.out.println("ERROR: Unable to read ini file: '"+iniFile+"'.");
System.exit(-1);
return;
}
DBConnector currentDBconnector=null;
final String dbClass=page.getStr("DBCLASS");
if(dbClass.length()>0)
{
final String dbService=page.getStr("DBSERVICE");
final String dbUser=page.getStr("DBUSER");
final String dbPass=page.getStr("DBPASS");
final int dbConns=page.getInt("DBCONNECTIONS");
final int dbPingIntMins=page.getInt("DBPINGINTERVALMINS");
if(dbConns == 0)
{
Log.errOut(Thread.currentThread().getName(),"Fatal error: DBCONNECTIONS in INI file is "+dbConns);
System.exit(-1);
}
final boolean dbReuse=page.getBoolean("DBREUSE");
final boolean dbTransact=page.getBoolean("DBTRANSACT");
final Map<String,String> dbParms=CMParms.parseEQParms(page.getStr("DBPARMS"),CMParms.spaceDelimiter,false);
final boolean useQue=!CMSecurity.isDisabled(CMSecurity.DisFlag.DBERRORQUE);
final boolean useQueStart=!CMSecurity.isDisabled(CMSecurity.DisFlag.DBERRORQUESTART);
CMProps.setUpLowVar(CMProps.Str.MUDSTATUS,"Booting: connecting to database");
currentDBconnector=new DBConnector(dbClass,dbService,dbUser,dbPass,dbParms,dbConns,dbPingIntMins,dbReuse,dbTransact,useQue,useQueStart);
currentDBconnector.reconnect();
CMLib.registerLibrary(new DBInterface(currentDBconnector,CMProps.getPrivateSubSet("DB.*")));
final DBConnection DBTEST=currentDBconnector.DBFetch();
if(DBTEST!=null)
currentDBconnector.DBDone(DBTEST);
if((DBTEST!=null)&&(currentDBconnector.amIOk())&&(CMLib.database().isConnected()))
{
Log.sysOut(Thread.currentThread().getName(),"Connected to "+currentDBconnector.service());
}
else
{
final String DBerrors=currentDBconnector.errorStatus().toString();
Log.errOut(Thread.currentThread().getName(),"Fatal database error: "+DBerrors);
return;
}
}
if((CMLib.database()==null)||(currentDBconnector==null))
{
Log.errOut(Thread.currentThread().getName(),"No registered database!");
System.exit(-1);
return;
}
// test the database
try
{
final CMFile F = new CMFile("/test.the.database",null);
if(F.exists())
Log.sysOut(Thread.currentThread().getName(),"Test file found .. hmm.. that was unexpected.");
}
catch(final Exception e)
{
Log.errOut(e);
Log.errOut("Database error! Panic shutdown!");
System.exit(-1);
}
CMClass.initialize();
Resources.initialize();
CMSecurity.instance();
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.AutoTitles());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CMJournals());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.BeanCounter());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CharCreation());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.Clans());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CMAbleMap());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CMAbleParms());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CMCatalog());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CMChannels());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CMColor());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CMMap());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CoffeeMaker());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.MUDPercolator());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.EnglishParser());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CoffeeUtensils());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CMEncoder());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CMGenEditor());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CoffeeFilter());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CMLister());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.Dice());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.DirtyLanguage());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.Sense());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.XMLManager());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.MUDZapper());
CMLib.registerLibrary(new com.planet_ink.coffee_mud.Libraries.CoffeeTime());
CMClass.addClass(CMObjectType.COMMON, new com.planet_ink.coffee_mud.Common.DefaultCharState());
CMClass.addClass(CMObjectType.COMMON, new com.planet_ink.coffee_mud.Common.DefaultCharStats());
CMClass.addClass(CMObjectType.COMMON, new com.planet_ink.coffee_mud.Common.DefaultPhyStats());
final MOB fakeMob = new StdMOB();
final Session session = new Session()
{
protected OutputStream bout=System.out;
protected MOB mob = fakeMob;
@Override
public String ID()
{
return "FakeSession";
}
@Override
public String name()
{
return ID();
}
@Override
public CMObject newInstance()
{
try
{
return getClass().newInstance();
}
catch (final Exception e)
{
return new FakeSession();
}
}
@Override
public CMObject copyOf()
{
try
{
return (CMObject) this.clone();
}
catch (final Exception e)
{
return newInstance();
}
}
@Override
public int compareTo(final CMObject o)
{
return CMClass.classID(this).compareToIgnoreCase(CMClass.classID(o));
}
@Override
public void initializeSession(final Socket s, final String groupName, final String introTextStr)
{
}
@Override
public String getGroupName()
{
return Thread.currentThread().getThreadGroup().getName();
}
@Override
public void setGroupName(final String group)
{
}
@Override
public long getStartTime()
{
return 0;
}
@Override
public int getGroupID()
{
return Thread.currentThread().getThreadGroup().getName().charAt(0);
}
@Override
public boolean isLockedUpWriting()
{
return false;
}
@Override
public void initializeClass()
{
}
@Override
public void run()
{
}
@Override
public boolean isRunning()
{
return false;
}
@Override
public boolean isPendingLogin(final String otherLoginName)
{
return false;
}
@Override
public void logout(final boolean b1)
{
}
@Override
public String getTerminalType()
{
return "Fake";
}
@Override
public void negotiateTelnetMode(final int code)
{
}
@Override
public boolean isAllowedMxp(final String tag)
{
return false;
}
@Override
public boolean isFake()
{
return false;
}
@Override
public void setIdleTimers()
{
}
@Override
public boolean sendGMCPEvent(final String eventName, final String json)
{
return false;
}
@Override
public void setFakeInput(final String input)
{
}
@Override
public boolean isAllowedMcp(final String packageName, final float version)
{
return false;
}
@Override
public boolean sendMcpCommand(final String packageCommand, final String parms)
{
return false;
}
@Override
public String[] getColorCodes()
{
return new String[255];
}
@Override
public boolean addSessionFilter(final SessionFilter filter)
{
return false;
}
@Override
public void onlyPrint(final String msg, final boolean noCache)
{
if (bout != null)
{
synchronized (bout)
{
try
{
bout.write(CMStrings.removeColors(msg).replaceAll("\n\r", "\n").getBytes());
}
catch (final Exception e)
{
Log.errOut("FakeSession", e);
}
}
}
}
@Override
public void onlyPrint(final String msg)
{
onlyPrint(msg, false);
}
@Override
public void rawOut(final String msg)
{
onlyPrint(msg, false);
}
@Override
public void rawPrintln(final String msg)
{
onlyPrint(msg + "\n", false);
}
@Override
public void rawPrint(final String msg)
{
onlyPrint(msg, false);
}
@Override
public void safeRawPrintln(final String msg)
{
onlyPrint(msg + "\n", false);
}
@Override
public void safeRawPrint(final String msg)
{
onlyPrint(msg, false);
}
@Override
public void stdPrint(final String msg)
{
onlyPrint(msg, false);
}
@Override
public void stdPrint(final Physical Source, final Environmental Target, final Environmental Tool, final String msg)
{
onlyPrint(msg, false);
}
@Override
public void stdPrintln(final String msg)
{
onlyPrint(msg + "\n", false);
}
@Override
public void stdPrintln(final Physical Source, final Environmental Target, final Environmental Tool, final String msg)
{
onlyPrint(msg + "\n", false);
}
@Override
public void rawCharsOut(final char[] c)
{
onlyPrint(new String(c), false);
}
@Override
public void print(final String msg)
{
onlyPrint(msg, false);
}
@Override
public void promptPrint(final String msg)
{
onlyPrint(msg, false);
}
@Override
public void print(final Physical Source, final Environmental Target, final Environmental Tool, final String msg)
{
onlyPrint(msg, false);
}
@Override
public void println(final String msg)
{
onlyPrint(msg + "\n", false);
}
@Override
public void println(final Physical Source, final Environmental Target, final Environmental Tool, final String msg)
{
onlyPrint(msg + "\n", false);
}
@Override
public void wraplessPrintln(final String msg)
{
onlyPrint(msg + "\n", false);
}
@Override
public void wraplessPrint(final String msg)
{
onlyPrint(msg, false);
}
@Override
public void colorOnlyPrintln(final String msg, final boolean noCache)
{
onlyPrint(msg + "\n", false);
}
@Override
public void colorOnlyPrint(final String msg, final boolean noCache)
{
onlyPrint(msg, false);
}
@Override
public void colorOnlyPrintln(final String msg)
{
onlyPrint(msg + "\n", false);
}
@Override
public void colorOnlyPrint(final String msg)
{
onlyPrint(msg, false);
}
@Override
public void setPromptFlag(final boolean truefalse)
{
}
@Override
public char hotkey(final long maxWait)
{
return ' ';
}
@Override
public String prompt(final String Message, final String Default)
{
onlyPrint(Message, false);
final String msg = readlineContinue();
if (msg.length() == 0)
return Default;
return msg;
}
@Override
public void prompt(final InputCallback callBack)
{
callBack.showPrompt();
callBack.setInput(readlineContinue());
callBack.callBack();
}
@Override
public String prompt(final String Message, final String Default, final long maxTime)
{
return prompt(Message, Default);
}
@Override
public String prompt(final String Message)
{
return prompt(Message, "");
}
@Override
public String prompt(final String Message, final long maxTime)
{
return prompt(Message, "");
}
@Override
public boolean confirm(final String Message, String Default)
{
if (Default.toUpperCase().startsWith("T"))
Default = "Y";
final String YN = choose(Message, "YN", Default, 0);
return (YN.equals("Y")) ? true : false;
}
@Override
public boolean confirm(final String Message, final String Default, final long maxTime)
{
return confirm(Message, Default, 0);
}
@Override
public String choose(final String Message, final String Choices, final String Default)
{
onlyPrint(Message, false);
final String msg = readlineContinue();
if (msg.length() == 0)
return Default;
if (Choices.toUpperCase().indexOf(msg.toUpperCase().trim()) >= 0)
return msg.toUpperCase().trim();
return Default;
}
@Override
public String choose(final String Message, final String Choices, final String Default, final long maxTime, final List<String> paramsOut) throws IOException
{
return choose(Message, Choices, Default);
}
@Override
public String choose(final String Message, final String Choices, final String Default, final long maxTime)
{
return choose(Message, Choices, Default);
}
@Override
public String blockingIn(final long timeoutMillis, final boolean filter)
{
return readlineContinue();
}
@Override
public String readlineContinue()
{
try
{
return new BufferedReader(new InputStreamReader(System.in)).readLine();
}
catch (final Exception e)
{
System.exit(-1);
return "";
}
}
@Override
public void setBeingSnoopedBy(final Session session, final boolean onOff)
{
}
@Override
public boolean isBeingSnoopedBy(final Session S)
{
return S == this;
}
@Override
public int snoopSuspension(final int x)
{
return 0;
}
@Override
public void stopSession(final boolean t1, final boolean t2, final boolean t3)
{
}
@Override
public boolean isStopped()
{
return false;
}
@Override
public boolean isAfk()
{
return false;
}
@Override
public void setAfkFlag(final boolean truefalse)
{
}
@Override
public String getAfkMessage()
{
return "";
}
@Override
public void setAFKMessage(final String str)
{
}
@Override
public List<String> getPreviousCMD()
{
return new Vector<String>();
}
@Override
public MOB mob()
{
return mob;
}
@Override
public void setMob(final MOB newmob)
{
mob = newmob;
}
@Override
public void setAccount(final PlayerAccount account)
{
}
@Override
public void setCurrentColor(final ColorState newcolor)
{
}
@Override
public void setLastColor(final ColorState newColor)
{
}
@Override
public ColorState getCurrentColor()
{
return CMLib.color().getNormalColor();
}
@Override
public ColorState getLastColor()
{
return CMLib.color().getNormalColor();
}
@Override
public int getWrap()
{
return 80;
}
@Override
public String getAddress()
{
return "";
}
@Override
public SessionStatus getStatus()
{
return SessionStatus.MAINLOOP;
}
@Override
public void setStatus(final SessionStatus newStatus)
{
}
@Override
public boolean isWaitingForInput()
{
return false;
}
@Override
public long getTotalMillis()
{
return 0;
}
@Override
public long getTotalTicks()
{
return 0;
}
@Override
public long getIdleMillis()
{
return 0;
}
@Override
public long getMillisOnline()
{
return 0;
}
@Override
public long getLastPKFight()
{
return 0;
}
@Override
public void setLastPKFight()
{
}
@Override
public long getLastNPCFight()
{
return 0;
}
@Override
public void setLastNPCFight()
{
}
@Override
public long getInputLoopTime()
{
return 0;
}
@Override
public void setInputLoopTime()
{
}
@Override
public List<String> getLastMsgs()
{
return new Vector<String>();
}
@Override
public void setServerTelnetMode(final int telnetCode, final boolean onOff)
{
}
@Override
public boolean getServerTelnetMode(final int telnetCode)
{
return false;
}
@Override
public void setClientTelnetMode(final int telnetCode, final boolean onOff)
{
}
@Override
public boolean getClientTelnetMode(final int telnetCode)
{
return false;
}
@Override
public void changeTelnetMode(final int telnetCode, final boolean onOff)
{
}
@Override
public void initTelnetMode(final int mobbitmap)
{
}
@Override
public int getSaveStatIndex()
{
return 0;
}
@Override
public String getStat(final String code)
{
return null;
}
@Override
public String[] getStatCodes()
{
return new String[0];
}
@Override
public boolean isStat(final String code)
{
return false;
}
@Override
public void setStat(final String code, final String val)
{
}
@Override
public long activeTimeMillis()
{
return 0;
}
@Override
public boolean autoLogin(final String name, final String password)
{
return false;
}
};
fakeMob.setSession(session);
fakeMob.setSoulMate(fakeMob);
fakeMob.setAttribute(MOB.Attrib.SYSOPMSGS, true);
final Shell shell = new Shell();
String command="";
String pwd="";
System.out.println("CoffeeMud VFShell started. Use 'exit' to quit.");
System.out.println("");
while((command!=null)&&(!command.equalsIgnoreCase("exit")))
{
try
{
pwd=(String)shell.executeInternal(fakeMob, 0, ".");
System.out.print(pwd+"> ");
command=new BufferedReader(new InputStreamReader(System.in)).readLine();
if((command!=null)&&(command.trim().length()>0)&&(!command.trim().toLowerCase().startsWith("exit")))
shell.execute(fakeMob, CMParms.parse("SHELL "+command), 0);
}
catch (final Exception e)
{
e.printStackTrace();
break;
}
}
currentDBconnector.killConnections();
}
});
try
{
t.start();
t.join();
}
catch (final InterruptedException e)
{
e.printStackTrace();
}
}
}