Use TelnetTransport to easily allow windows telnet to connect to your ConsoleServer. More...
#include <TelnetTransport.h>
Inherits TransportInterface.
Classes | |
struct | TelnetClient |
Public Member Functions | |
TelnetTransport () | |
virtual | ~TelnetTransport () |
bool | Start (unsigned short port, bool serverMode) |
void | Stop (void) |
Stop the transport provider. You can clear memory and shutdown threads here. | |
void | Send (SystemAddress systemAddress, const char *data,...) |
void | CloseConnection (SystemAddress systemAddress) |
Packet * | Receive (void) |
void | DeallocatePacket (Packet *packet) |
SystemAddress | HasNewIncomingConnection (void) |
SystemAddress | HasLostConnection (void) |
CommandParserInterface * | GetCommandParser (void) |
void | SetSendSuffix (const char *suffix) |
void | SetSendPrefix (const char *prefix) |
Protected Member Functions | |
void | AutoAllocate (void) |
bool | ReassembleLine (TelnetTransport::TelnetClient *telnetClient, unsigned char c) |
Protected Attributes | |
TCPInterface * | tcpInterface |
DataStructures::List < TelnetClient * > | remoteClients |
char * | sendSuffix |
char * | sendPrefix |
Use TelnetTransport to easily allow windows telnet to connect to your ConsoleServer.
To run Windows telnet, go to your start menu, click run, and in the edit box type "telnet <IP>" where <IP> is the ip address.
of your ConsoleServer (most likely the same IP as your game).
This implementation always echos commands.
Definition at line 24 of file TelnetTransport.h.
TelnetTransport::TelnetTransport | ( | ) |
Definition at line 19 of file TelnetTransport.cpp.
TelnetTransport::~TelnetTransport | ( | ) | [virtual] |
void TelnetTransport::AutoAllocate | ( | void | ) | [protected] |
void TelnetTransport::CloseConnection | ( | SystemAddress | systemAddress | ) | [virtual] |
Disconnect systemAddress . The binary address and port defines the SystemAddress structure.
[in] | systemAddress | The player/address to disconnect |
Implements TransportInterface.
Definition at line 85 of file TelnetTransport.cpp.
void TelnetTransport::DeallocatePacket | ( | Packet * | packet | ) | [virtual] |
Deallocate the Packet structure returned by Receive
[in] | The | packet to deallocate |
Implements TransportInterface.
Definition at line 208 of file TelnetTransport.cpp.
CommandParserInterface * TelnetTransport::GetCommandParser | ( | void | ) | [virtual] |
Your transport provider can itself have command parsers if the transport layer has user-modifiable features For example, your transport layer may have a password which you want remote users to be able to set or you may want to allow remote users to turn on or off command echo
Implements TransportInterface.
Definition at line 287 of file TelnetTransport.cpp.
SystemAddress TelnetTransport::HasLostConnection | ( | void | ) | [virtual] |
If a system loses the connection, you should queue that event and return the systemAddress/address of that player in this function.
Implements TransportInterface.
Definition at line 268 of file TelnetTransport.cpp.
SystemAddress TelnetTransport::HasNewIncomingConnection | ( | void | ) | [virtual] |
If a new system connects to you, you should queue that event and return the systemAddress/address of that player in this function.
Implements TransportInterface.
Definition at line 214 of file TelnetTransport.cpp.
bool TelnetTransport::ReassembleLine | ( | TelnetTransport::TelnetClient * | telnetClient, | |
unsigned char | c | |||
) | [protected] |
Packet * TelnetTransport::Receive | ( | void | ) | [virtual] |
Return a string. The string should be allocated and written to Packet::data . The byte length should be written to Packet::length . The player/address should be written to Packet::systemAddress If your transport protocol adds special formatting to the data stream you should parse it out before returning it in the packet and thus only return a string in Packet::data
Implements TransportInterface.
Definition at line 89 of file TelnetTransport.cpp.
void TelnetTransport::Send | ( | SystemAddress | systemAddress, | |
const char * | data, | |||
... | ||||
) | [virtual] |
Send a null-terminated string to systemAddress If your transport method requires particular formatting of the outgoing data (e.g. you don't just send strings) you can do it here and parse it out in Receive().
[in] | systemAddress | The player to send the string to |
[in] | data | format specifier - same as RAKNET_DEBUG_PRINTF |
[in] | ... | format specification arguments - same as RAKNET_DEBUG_PRINTF |
Implements TransportInterface.
Definition at line 51 of file TelnetTransport.cpp.
void TelnetTransport::SetSendPrefix | ( | const char * | prefix | ) |
Definition at line 304 of file TelnetTransport.cpp.
void TelnetTransport::SetSendSuffix | ( | const char * | suffix | ) |
Definition at line 291 of file TelnetTransport.cpp.
bool TelnetTransport::Start | ( | unsigned short | port, | |
bool | serverMode | |||
) | [virtual] |
Start the transport provider on the indicated port.
[in] | port | The port to start the transport provider on |
[in] | serverMode | If true, you should allow incoming connections (I don't actually use this anywhere) |
Implements TransportInterface.
Definition at line 33 of file TelnetTransport.cpp.
void TelnetTransport::Stop | ( | void | ) | [virtual] |
Stop the transport provider. You can clear memory and shutdown threads here.
Implements TransportInterface.
Definition at line 40 of file TelnetTransport.cpp.
DataStructures::List<TelnetClient*> TelnetTransport::remoteClients [protected] |
Definition at line 55 of file TelnetTransport.h.
char * TelnetTransport::sendPrefix [protected] |
Definition at line 57 of file TelnetTransport.h.
char* TelnetTransport::sendSuffix [protected] |
Definition at line 57 of file TelnetTransport.h.
TCPInterface* TelnetTransport::tcpInterface [protected] |
Definition at line 50 of file TelnetTransport.h.