* XMLData now contains a GetData() method for returning data from the stored data collection. * XMLData now contains a Load() method for loading a previously saved XML data file. * StandardCharacter now automatically generates a filename. * StandardCharacter.Connected added. Use Connected to check if they are connected to the server regardless of the values for Enabled and LoggedIn. LoggedIn is now true once the Login command is completed. * Default Character Role is now Player. * Server.ServerOwner property added. When a character is logged in matching the ServerOwner name, it will automatically be assigned the Admin role. * StandardCharacter.ExecuteSilentCommand() method added for executing a command and not having the "Command: " line printed to the screen when the command is completed. Useful for daisy chained commands. * StandardCharacter login code is now 100% completed. Including save/load code and new character creation. * StandardCharacter.SetRole() method added. Admins can set the role of any other character in the game if they want to. * BaseScript & StandardCharacter now have their Load() code fully implemented. They can save and load their files now. * Player creation command added. Can only be executed from within the login command. If it is executed from any other object it will bail. * Stop command now only works when a Character with Role = Admin issues the command. During development of a MUD Game, this would typically be the Server.ServerOwner character who will have Admin rights. * ConnectionManager had some bugs fixed such as not removing Threads from the Thread collection when a character disconnected. Also re-organized the character connection code some.
89 lines
3.1 KiB
C#
89 lines
3.1 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Text.RegularExpressions;
|
|
using System.IO;
|
|
using System.Diagnostics;
|
|
|
|
using MudEngine.Core.Interface;
|
|
using MudEngine.Game;
|
|
using MudEngine.Game.Characters;
|
|
using MudEngine.Game.Environment;
|
|
using MudEngine.GameScripts;
|
|
|
|
namespace MudEngine.GameScripts.Commands
|
|
{
|
|
public class CommandCreatePlayer : ICommand
|
|
{
|
|
|
|
public string Name { get; set; }
|
|
|
|
public string Description { get; set; }
|
|
|
|
public List<string> Help { get; set; }
|
|
|
|
public CommandCreatePlayer()
|
|
{
|
|
Help = new List<string>();
|
|
Name = "CreatePlayer";
|
|
Description = "Account login command.";
|
|
}
|
|
|
|
public Boolean Execute(string command, Game.Characters.StandardCharacter character)
|
|
{
|
|
//reference to the Characters Game.
|
|
StandardGame game = character.Game;
|
|
Boolean buildingPassword = true;
|
|
|
|
//We need to check if the 3rd Frame on the stack is the CommandLogin Type.
|
|
//If it isn't, then another Type executed this command and we don't allow it.
|
|
StackTrace trace = new StackTrace();
|
|
String callingType = trace.GetFrame(3).GetMethod().ReflectedType.Name;
|
|
|
|
//Don't allow anything other than the Login command to start the
|
|
//character creation process.
|
|
if (callingType != "CommandLogin")
|
|
{
|
|
character.SendMessage("Invalid Command Used.");
|
|
return false;
|
|
}
|
|
|
|
//Make sure we build a proper password.
|
|
while (buildingPassword)
|
|
{
|
|
character.SendMessage("Please enter a password for this character: ", false);
|
|
String password1, password2;
|
|
password1 = character.GetInput();
|
|
|
|
//We do not perform any IsLetterOrDigit() checks on passwords. The more
|
|
//special characters the better.
|
|
//We do however want to make sure the length of the password is sufficient
|
|
if (password1.Length < character.Game.MinimumPasswordSize)
|
|
{
|
|
character.SendMessage("Passwords must have a minimum of " + character.Game.MinimumPasswordSize.ToString() + " characters!");
|
|
continue;
|
|
}
|
|
|
|
character.SendMessage("Please re-enter your password for confirmation: ", false);
|
|
password2 = character.GetInput();
|
|
|
|
if (password1 == password2)
|
|
{
|
|
buildingPassword = false;
|
|
character.Password = password1;
|
|
}
|
|
else
|
|
{
|
|
character.SendMessage("Passwords did not match!");
|
|
continue;
|
|
}
|
|
}
|
|
|
|
//TODO: Create a class and setup Stats.
|
|
character.Save(character.Filename, false);
|
|
|
|
return true;
|
|
}
|
|
}
|
|
}
|