/* * Original work: Copyright (c) 2014, Oculus VR, Inc. * All rights reserved. * * This source code is licensed under the BSD-style license found in the * RakNet License.txt file in the licenses directory of this source tree. An additional grant * of patent rights can be found in the RakNet Patents.txt file in the same directory. * * * Modified work: Copyright (c) 2016-2017, SLikeSoft UG (haftungsbeschränkt) * * This source code was modified by SLikeSoft. Modifications are licensed under the MIT-style * license found in the license.txt file in the root directory of this source tree. */ #include #include #include #include "slikenet/GetTime.h" #include "slikenet/peerinterface.h" #include "slikenet/MessageIdentifiers.h" #include "slikenet/types.h" #include "slikenet/sleep.h" #include "slikenet/FullyConnectedMesh2.h" #include "slikenet/ConnectionGraph2.h" #include #include "slikenet/SocketLayer.h" #include "slikenet/Kbhit.h" #include "slikenet/PacketLogger.h" #include "slikenet/BitStream.h" using namespace SLNet; SLNet::RakPeerInterface *rakPeer; int main() { FullyConnectedMesh2 fcm2; ConnectionGraph2 cg2; rakPeer= SLNet::RakPeerInterface::GetInstance(); rakPeer->AttachPlugin(&fcm2); rakPeer->AttachPlugin(&cg2); fcm2.SetAutoparticipateConnections(true); SLNet::SocketDescriptor sd; sd.socketFamily=AF_INET; // Only IPV4 supports broadcast on 255.255.255.255 sd.port=60000; while (IRNS2_Berkley::IsPortInUse(sd.port, sd.hostAddress, sd.socketFamily, SOCK_DGRAM)==true) sd.port++; StartupResult sr = rakPeer->Startup(8,&sd,1); RakAssert(sr==RAKNET_STARTED); rakPeer->SetMaximumIncomingConnections(8); rakPeer->SetTimeoutTime(1000, SLNet::UNASSIGNED_SYSTEM_ADDRESS); printf("Our guid is %s\n", rakPeer->GetGuidFromSystemAddress(SLNet::UNASSIGNED_SYSTEM_ADDRESS).ToString()); printf("Started on %s\n", rakPeer->GetMyBoundAddress().ToString(true)); // BitStream contextBs; // contextBs.Write(RakString("Our guid is %s\n", rakPeer->GetGuidFromSystemAddress(SLNet::UNASSIGNED_SYSTEM_ADDRESS).ToString())); // fcm2.SetMyContext(&contextBs); // PacketLogger packetLogger; // rakPeer->AttachPlugin(&packetLogger); // packetLogger.SetLogDirectMessages(false); bool quit=false; SLNet::Packet *packet; char ch; while (!quit) { for (packet = rakPeer->Receive(); packet; rakPeer->DeallocatePacket(packet), packet = rakPeer->Receive()) { switch (packet->data[0]) { case ID_DISCONNECTION_NOTIFICATION: // Connection lost normally printf("ID_DISCONNECTION_NOTIFICATION\n"); break; case ID_NEW_INCOMING_CONNECTION: // Somebody connected. We have their IP now printf("ID_NEW_INCOMING_CONNECTION from %s. guid=%s.\n", packet->systemAddress.ToString(true), packet->guid.ToString()); break; case ID_CONNECTION_REQUEST_ACCEPTED: // Somebody connected. We have their IP now printf("ID_CONNECTION_REQUEST_ACCEPTED from %s. guid=%s.\n", packet->systemAddress.ToString(true), packet->guid.ToString()); break; case ID_CONNECTION_LOST: // Couldn't deliver a reliable packet - i.e. the other system was abnormally // terminated printf("ID_CONNECTION_LOST\n"); break; case ID_ADVERTISE_SYSTEM: if (packet->guid!=rakPeer->GetMyGUID()) rakPeer->Connect(packet->systemAddress.ToString(false), packet->systemAddress.GetPort(),0,0); break; case ID_FCM2_NEW_HOST: { if (packet->guid==rakPeer->GetMyGUID()) printf("Got new host (ourselves)"); else printf("Got new host %s, GUID=%s", packet->systemAddress.ToString(true), packet->guid.ToString()); SLNet::BitStream bs(packet->data,packet->length,false); bs.IgnoreBytes(1); RakNetGUID oldHost; bs.Read(oldHost); // If oldHost is different then the current host, then we lost connection to the host if (oldHost!=UNASSIGNED_RAKNET_GUID) printf(". Oldhost Guid=%s\n", oldHost.ToString()); else printf(". (First reported host)\n"); } break; // case ID_REMOTE_NEW_INCOMING_CONNECTION: // { // uint32_t count; // SLNet::BitStream bsIn(packet->data, packet->length,false); // bsIn.IgnoreBytes(1); // bsIn.Read(count); // SystemAddress sa; // RakNetGUID guid; // printf("ID_REMOTE_NEW_INCOMING_CONNECTION from %s\n", packet->systemAddress.ToString(true)); // for (uint32_t i=0; i < count; i++) // { // bsIn.Read(sa); // bsIn.Read(guid); // // printf("%s ", sa.ToString(true)); // } // printf("\n"); // } } } if (_kbhit()) { ch=_getch(); if (ch==' ') { DataStructures::List participantList; fcm2.GetParticipantList(participantList); printf("%i participants\n", participantList.Size()); // for (unsigned i=0; i < participantList.Size(); i++) // { // BitStream userContext; // fcm2.GetParticipantContext(participantList[i], &userContext); // RakString str; // userContext.Read(str); // printf("%u. %s: %s", i+1, participantList[i].ToString(), str.C_String()); // } } if (ch=='q' || ch=='Q') { printf("Quitting.\n"); quit=true; } } RakSleep(30); for (int i=0; i < 32; i++) { if (rakPeer->GetInternalID(SLNet::UNASSIGNED_SYSTEM_ADDRESS,0).GetPort()!=60000+i) rakPeer->AdvertiseSystem("255.255.255.255", 60000+i, 0,0,0); } } SLNet::RakPeerInterface::DestroyInstance(rakPeer); return 0; }