mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-26 07:16:11 -05:00
Added Code to convert retroshare-nogui into an "Introduction Server".
Perhaps the community can use this instead of their existing certificate exchanger. The way it works: - Designed to be coupled up with a WEB Interface to allow new users to interact with each other. - Automatically sets up some Chat Lobbies, so that the new users can chat to each other. - If you drop a Certificate File into the NEWCERT directory, it is automatically loaded as a friend. - These Certificates automatically expire after a fixed period (2 Weeks at the moment). So the idea is that Users upload their Certificates to the Intro WebServer, then they have two weeks to test out Retroshare, and use the Intro Server to make some RS Friends. To enable this Build, edit the .pro file. git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@4900 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
parent
fb7bc3e832
commit
446db939b2
538
retroshare-nogui/src/introserver.cc
Normal file
538
retroshare-nogui/src/introserver.cc
Normal file
@ -0,0 +1,538 @@
|
||||
|
||||
/*
|
||||
* RetroShare C++ Interface.
|
||||
*
|
||||
* Copyright 2012-2012 by Robert Fernie.
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Library General Public
|
||||
* License Version 2.1 as published by the Free Software Foundation.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Library General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Library General Public
|
||||
* License along with this library; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
||||
* USA.
|
||||
*
|
||||
* Please report all bugs and problems to "retroshare@lunamutt.com".
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
#include <retroshare/rsmsgs.h>
|
||||
#include <retroshare/rspeers.h>
|
||||
#include "util/folderiterator.h"
|
||||
#include "util/rsdir.h"
|
||||
|
||||
#include "introserver.h"
|
||||
|
||||
#include <dirent.h>
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
#include <fcntl.h>
|
||||
#include <unistd.h>
|
||||
#include <stdio.h>
|
||||
#include <fstream>
|
||||
|
||||
|
||||
|
||||
#include <iostream>
|
||||
|
||||
#define RSIS_CHECKTIME 60
|
||||
#define MAX_PEER_AGE (3600 * 24 * 14) // 2 weeks.
|
||||
//#define MAX_PEER_AGE (600) // 10 minutes - for testing
|
||||
|
||||
RsIntroServer::RsIntroServer()
|
||||
:mStartTS(0)
|
||||
{
|
||||
std::cerr << "RsIntroServer::RsIntroServer()";
|
||||
std::cerr << std::endl;
|
||||
|
||||
mStartTS = time(NULL);
|
||||
mLastCheck = 0;
|
||||
mCertCheckTime = 0;
|
||||
|
||||
mMaxPeerAge = MAX_PEER_AGE;
|
||||
|
||||
setupChatLobbies();
|
||||
|
||||
mPeersFile = "./STORAGE/peers.txt";
|
||||
mCertLoadPath = "./NEWCERTS";
|
||||
mStorePeers = new RsIntroStore(mPeersFile);
|
||||
mStorePeers->loadPeers();
|
||||
}
|
||||
|
||||
|
||||
|
||||
int RsIntroServer::tick()
|
||||
{
|
||||
time_t now = time(NULL);
|
||||
|
||||
if (mLastCheck + RSIS_CHECKTIME < now )
|
||||
{
|
||||
std::cerr << "RsIntroServer::tick() Check Cycle";
|
||||
std::cerr << std::endl;
|
||||
|
||||
checkForNewCerts();
|
||||
|
||||
cleanOldPeers();
|
||||
|
||||
displayPeers();
|
||||
|
||||
mLastCheck = now;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
int RsIntroServer::setupChatLobbies()
|
||||
{
|
||||
std::cerr << "RsIntroServer::setupChatLobbies()";
|
||||
std::cerr << std::endl;
|
||||
|
||||
std::string englishLobbyName = "Meeting Place (English)";
|
||||
std::string germanLobbyName = "Meeting Place (German)";
|
||||
std::string frenchLobbyName = "Meeting Place (French)";
|
||||
|
||||
std::list<std::string> emptyList;
|
||||
uint32_t lobby_privacy_type = RS_CHAT_LOBBY_PRIVACY_LEVEL_PUBLIC;
|
||||
|
||||
mEnglishLobby = rsMsgs->createChatLobby(englishLobbyName, emptyList, lobby_privacy_type);
|
||||
mFrenchLobby = rsMsgs->createChatLobby(frenchLobbyName, emptyList, lobby_privacy_type);
|
||||
mGermanLobby = rsMsgs->createChatLobby(germanLobbyName, emptyList, lobby_privacy_type);
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
int RsIntroServer::addCertificateFile(std::string filepath)
|
||||
{
|
||||
std::cerr << "RsIntroServer::addCertificateFile(" << filepath << ")";
|
||||
std::cerr << std::endl;
|
||||
|
||||
std::string certGPG;
|
||||
|
||||
|
||||
FILE *fd = fopen(filepath.c_str(), "r");
|
||||
if (!fd)
|
||||
{
|
||||
std::cerr << "RsIntroServer::addCertificateFile(" << filepath << ") FAILED to open file";
|
||||
std::cerr << std::endl;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#define MAX_BUFFER 10240
|
||||
char BUFFER[MAX_BUFFER];
|
||||
|
||||
while(BUFFER == fgets(BUFFER, MAX_BUFFER, fd))
|
||||
{
|
||||
certGPG += BUFFER;
|
||||
}
|
||||
|
||||
std::cerr << "Read in Certificate: " << std::endl;
|
||||
std::cerr << "==========================================================" << std::endl;
|
||||
std::cerr << certGPG;
|
||||
std::cerr << std::endl;
|
||||
std::cerr << "==========================================================" << std::endl;
|
||||
|
||||
return addNewUser(certGPG);
|
||||
}
|
||||
|
||||
|
||||
int RsIntroServer::addNewUser(std::string certGPG)
|
||||
{
|
||||
std::cerr << "RsIntroServer::addNewUser()";
|
||||
std::cerr << std::endl;
|
||||
|
||||
RsPeerDetails pd;
|
||||
std::string error_string;
|
||||
|
||||
bool ok = rsPeers->loadDetailsFromStringCert(certGPG, pd,error_string);
|
||||
|
||||
if (ok)
|
||||
{
|
||||
std::string gpgId = pd.gpg_id;
|
||||
std::string sslId;
|
||||
if (!pd.isOnlyGPGdetail)
|
||||
{
|
||||
sslId = pd.id;
|
||||
}
|
||||
|
||||
std::cerr << "RsIntroServer::addNewUser() GPGID: " << gpgId << " SSLID: " << sslId;
|
||||
std::cerr << std::endl;
|
||||
|
||||
rsPeers->addFriend(sslId, gpgId);
|
||||
|
||||
/* add to internal storage */
|
||||
mStorePeers->addPeer(pd);
|
||||
mStorePeers->savePeers();
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
std::cerr << "RsIntroServer::addNewUser() Load Failed!";
|
||||
std::cerr << std::endl;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
int RsIntroServer::checkForNewCerts()
|
||||
{
|
||||
std::cerr << "RsIntroServer::checkForNewCerts()";
|
||||
std::cerr << std::endl;
|
||||
|
||||
/* check for new files */
|
||||
librs::util::FolderIterator dirIt(mCertLoadPath);
|
||||
if (!dirIt.isValid())
|
||||
{
|
||||
std::cerr << "RsIntroServer::checkForNewCerts()";
|
||||
std::cerr << " Missing Dir: " << mCertLoadPath << std::endl;
|
||||
#ifdef RSIS_DEBUG
|
||||
#endif
|
||||
return false;
|
||||
}
|
||||
|
||||
std::list<std::string> newCertFiles;
|
||||
std::list<std::string>::iterator it;
|
||||
|
||||
time_t now = time(NULL);
|
||||
time_t oldCheckTime = mCertCheckTime;
|
||||
mCertCheckTime = now;
|
||||
struct stat64 buf;
|
||||
|
||||
while(dirIt.readdir())
|
||||
{
|
||||
/* check entry type */
|
||||
std::string fname;
|
||||
dirIt.d_name(fname);
|
||||
std::string fullname = mCertLoadPath + "/" + fname;
|
||||
#ifdef RSIS_DEBUG
|
||||
std::cerr << "calling stats on " << fullname <<std::endl;
|
||||
#endif
|
||||
|
||||
#ifdef WINDOWS_SYS
|
||||
std::wstring wfullname;
|
||||
librs::util::ConvertUtf8ToUtf16(fullname, wfullname);
|
||||
if (-1 != _wstati64(wfullname.c_str(), &buf))
|
||||
#else
|
||||
if (-1 != stat64(fullname.c_str(), &buf))
|
||||
#endif
|
||||
{
|
||||
#ifdef RSIS_DEBUG
|
||||
std::cerr << "buf.st_mode: " << buf.st_mode <<std::endl;
|
||||
#endif
|
||||
if (S_ISDIR(buf.st_mode))
|
||||
{
|
||||
/* ignore */
|
||||
#ifdef RSIS_DEBUG
|
||||
std::cerr << "Ignoring Directory" << std::endl;
|
||||
#endif
|
||||
|
||||
|
||||
}
|
||||
else if (S_ISREG(buf.st_mode))
|
||||
{
|
||||
/* check timestamp, push into queue */
|
||||
if ((buf.st_mtime > oldCheckTime) && (buf.st_size > MIN_CERT_SIZE))
|
||||
{
|
||||
#ifdef RSIS_DEBUG
|
||||
std::cerr << "Adding New File: " << fullname << std::endl;
|
||||
#endif
|
||||
newCertFiles.push_back(fullname);
|
||||
}
|
||||
else
|
||||
{
|
||||
#ifdef RSIS_DEBUG
|
||||
std::cerr << "Ignoring Old File: " << fullname << std::endl;
|
||||
std::cerr << "\t it is: " << now - buf.st_mtime << " secs old" << std::endl;
|
||||
#endif
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
for(it = newCertFiles.begin(); it != newCertFiles.end(); it++)
|
||||
{
|
||||
std::cerr << "RsIntroServer::checkForNewCerts() adding: " << *it;
|
||||
std::cerr << std::endl;
|
||||
|
||||
/* add Certificate */
|
||||
addCertificateFile(*it);
|
||||
sleep(1);
|
||||
|
||||
std::cerr << "RsIntroServer::checkForNewCerts() removing: " << *it;
|
||||
std::cerr << std::endl;
|
||||
remove(it->c_str());
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
int RsIntroServer::cleanOldPeers()
|
||||
{
|
||||
std::cerr << "RsIntroServer::cleanOldPeers()";
|
||||
std::cerr << std::endl;
|
||||
|
||||
std::list<std::string> oldIds;
|
||||
std::list<std::string>::iterator it;
|
||||
|
||||
time_t now = time(NULL);
|
||||
time_t before = now - mMaxPeerAge;
|
||||
|
||||
mStorePeers->getPeersBeforeTS(before, oldIds);
|
||||
|
||||
for(it = oldIds.begin(); it != oldIds.end(); it++)
|
||||
{
|
||||
std::cerr << "RsIntroServer::cleanOldPeers() Removing: " << *it;
|
||||
std::cerr << std::endl;
|
||||
|
||||
rsPeers->removeFriend(*it);
|
||||
mStorePeers->removePeer(*it);
|
||||
}
|
||||
|
||||
mStorePeers->savePeers();
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
|
||||
int RsIntroServer::displayPeers()
|
||||
{
|
||||
std::cerr << "RsIntroServer::displayPeers()";
|
||||
std::cerr << std::endl;
|
||||
|
||||
std::list<std::string> ids;
|
||||
std::list<std::string>::iterator it;
|
||||
|
||||
rsPeers->getGPGAcceptedList(ids);
|
||||
|
||||
for(it = ids.begin(); it != ids.end(); it++)
|
||||
{
|
||||
std::cerr << "GPGID: " << *it;
|
||||
|
||||
if (mStorePeers->isValid(*it))
|
||||
{
|
||||
//std::cerr << " RsIS Flags: " << flags;
|
||||
}
|
||||
else
|
||||
{
|
||||
std::cerr << " Warning Unknown by RsIS ";
|
||||
}
|
||||
|
||||
std::cerr << " => SSLIDS: ";
|
||||
std::list<std::string> sslIds;
|
||||
std::list<std::string>::iterator sit;
|
||||
rsPeers->getAssociatedSSLIds(*it, sslIds);
|
||||
|
||||
for(sit = sslIds.begin(); sit != sslIds.end(); sit++)
|
||||
{
|
||||
std::cerr << *sit;
|
||||
if (rsPeers->isOnline(*sit))
|
||||
{
|
||||
std::cerr << " (ONLINE!), ";
|
||||
}
|
||||
else
|
||||
{
|
||||
std::cerr << " (Offline), ";
|
||||
}
|
||||
}
|
||||
std::cerr << std::endl;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/*****************************************************************************************/
|
||||
|
||||
|
||||
RsIntroStore::RsIntroStore(std::string storefile)
|
||||
{
|
||||
std::cerr << "RsIntroStore::RsIntroStore(" << storefile << ")";
|
||||
std::cerr << std::endl;
|
||||
|
||||
mStoreFile = storefile;
|
||||
mTempStoreFile = storefile + ".tmp";
|
||||
}
|
||||
|
||||
|
||||
bool RsIntroStore::addPeer(const RsPeerDetails &pd)
|
||||
{
|
||||
std::cerr << "RsIntroStore::addPeer()";
|
||||
std::cerr << std::endl;
|
||||
|
||||
std::string gpgId = pd.gpg_id;
|
||||
|
||||
std::map<std::string, storeData>::iterator it;
|
||||
it = mGpgData.find(gpgId);
|
||||
if (it != mGpgData.end())
|
||||
{
|
||||
std::cerr << "RsIntroStore::addPeer() ERROR peer already exists!";
|
||||
std::cerr << std::endl;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
storeData sd;
|
||||
sd.mAdded = time(NULL);
|
||||
sd.mFlags = 0;
|
||||
|
||||
mGpgData[gpgId] = sd;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
bool RsIntroStore::removePeer(std::string gpgId)
|
||||
{
|
||||
std::cerr << "RsIntroStore::removePeer()";
|
||||
std::cerr << std::endl;
|
||||
|
||||
std::map<std::string, storeData>::iterator it;
|
||||
it = mGpgData.find(gpgId);
|
||||
if (it != mGpgData.end())
|
||||
{
|
||||
mGpgData.erase(it);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
bool RsIntroStore::isValid(std::string gpgId)
|
||||
{
|
||||
std::map<std::string, storeData>::iterator it;
|
||||
it = mGpgData.find(gpgId);
|
||||
return (it != mGpgData.end());
|
||||
}
|
||||
|
||||
uint32_t RsIntroStore::getFlags(std::string gpgId)
|
||||
{
|
||||
std::cerr << "RsIntroStore::removePeer()";
|
||||
std::cerr << std::endl;
|
||||
|
||||
std::map<std::string, storeData>::iterator it;
|
||||
it = mGpgData.find(gpgId);
|
||||
if (it != mGpgData.end())
|
||||
{
|
||||
return it->second.mFlags;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
bool RsIntroStore::getPeersBeforeTS(time_t ts, std::list<std::string> &plist)
|
||||
{
|
||||
std::cerr << "RsIntroStore::getPeersBeforeTS()";
|
||||
std::cerr << std::endl;
|
||||
|
||||
std::map<std::string, storeData>::iterator it;
|
||||
for(it = mGpgData.begin(); it != mGpgData.end(); it++)
|
||||
{
|
||||
std::cerr << "\t Checking: " << it->first << " Added: " << it->second.mAdded << " vs TS: " << ts;
|
||||
std::cerr << std::endl;
|
||||
|
||||
if (it->second.mAdded < ts)
|
||||
{
|
||||
std::cerr << "YES Adding OLD: " << it->first;
|
||||
std::cerr << std::endl;
|
||||
|
||||
plist.push_back(it->first);
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
bool RsIntroStore::savePeers()
|
||||
{
|
||||
std::cerr << "RsIntroStore::savePeers()";
|
||||
std::cerr << std::endl;
|
||||
|
||||
FILE *fd = fopen(mTempStoreFile.c_str(), "w");
|
||||
if (!fd)
|
||||
{
|
||||
std::cerr << "RsIntroStore::savePeers() Cannot open tmp file";
|
||||
std::cerr << std::endl;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
std::map<std::string, storeData>::iterator it;
|
||||
|
||||
for(it = mGpgData.begin(); it != mGpgData.end(); it++)
|
||||
{
|
||||
fprintf(fd, "%s %d %u\n", it->first.c_str(), (int) it->second.mAdded, it->second.mFlags);
|
||||
}
|
||||
fclose(fd);
|
||||
|
||||
/* now move to final location */
|
||||
RsDirUtil::renameFile(mTempStoreFile,mStoreFile);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool RsIntroStore::loadPeers()
|
||||
{
|
||||
std::cerr << "RsIntroStore::loadPeers()";
|
||||
std::cerr << std::endl;
|
||||
|
||||
/* read from the file */
|
||||
FILE *fd = fopen(mStoreFile.c_str(), "r");
|
||||
if (!fd)
|
||||
{
|
||||
std::cerr << "RsIntroStore::loadPeers() Cannot open file, trying tmp";
|
||||
std::cerr << std::endl;
|
||||
|
||||
FILE *fd = fopen(mTempStoreFile.c_str(), "r");
|
||||
if (!fd)
|
||||
{
|
||||
std::cerr << "RsIntroStore::loadPeers() Cannot open tmp file";
|
||||
std::cerr << std::endl;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
char BUFFER[MAX_BUFFER];
|
||||
char certId[MAX_BUFFER];
|
||||
|
||||
while(BUFFER == fgets(BUFFER, MAX_BUFFER, fd))
|
||||
{
|
||||
int addTs;
|
||||
uint32_t flags;
|
||||
if (3 == sscanf(BUFFER, "%s %d %u", certId, &addTs, &flags))
|
||||
{
|
||||
storeData sd;
|
||||
sd.mAdded = addTs;
|
||||
sd.mFlags = flags;
|
||||
|
||||
std::string gpgId(certId);
|
||||
|
||||
mGpgData[gpgId] = sd;
|
||||
|
||||
std::cerr << "\t" << gpgId << " Added: " << addTs << " Flags: " << flags;
|
||||
std::cerr << std::endl;
|
||||
}
|
||||
}
|
||||
|
||||
fclose(fd);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
101
retroshare-nogui/src/introserver.h
Normal file
101
retroshare-nogui/src/introserver.h
Normal file
@ -0,0 +1,101 @@
|
||||
|
||||
/*
|
||||
* RetroShare C++ Interface.
|
||||
*
|
||||
* Copyright 2012-2012 by Robert Fernie.
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Library General Public
|
||||
* License Version 2.1 as published by the Free Software Foundation.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Library General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Library General Public
|
||||
* License along with this library; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
||||
* USA.
|
||||
*
|
||||
* Please report all bugs and problems to "retroshare@lunamutt.com".
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef RS_INTRO_SERVER_H
|
||||
#define RS_INTRO_SERVER_H
|
||||
|
||||
#include <retroshare/rspeers.h>
|
||||
#include <retroshare/rsmsgs.h>
|
||||
#include <stdio.h>
|
||||
#include <iostream>
|
||||
|
||||
#define MIN_CERT_SIZE 100
|
||||
|
||||
class RsIntroStore;
|
||||
|
||||
class RsIntroServer
|
||||
{
|
||||
public:
|
||||
|
||||
RsIntroServer();
|
||||
|
||||
int tick();
|
||||
int displayPeers();
|
||||
|
||||
private:
|
||||
|
||||
int addCertificateFile(std::string);
|
||||
int addNewUser(std::string certificate);
|
||||
int setupChatLobbies();
|
||||
|
||||
int checkForNewCerts();
|
||||
int cleanOldPeers();
|
||||
|
||||
time_t mStartTS;
|
||||
time_t mLastCheck;
|
||||
int mMaxPeerAge;
|
||||
|
||||
std::string mCertLoadPath;
|
||||
time_t mCertCheckTime;
|
||||
|
||||
std::string mPeersFile;
|
||||
RsIntroStore *mStorePeers;
|
||||
|
||||
ChatLobbyId mEnglishLobby;
|
||||
ChatLobbyId mFrenchLobby;
|
||||
ChatLobbyId mGermanLobby;
|
||||
};
|
||||
|
||||
|
||||
class storeData
|
||||
{
|
||||
public:
|
||||
time_t mAdded;
|
||||
uint32_t mFlags;
|
||||
};
|
||||
|
||||
|
||||
class RsIntroStore
|
||||
{
|
||||
public:
|
||||
RsIntroStore(std::string storefile);
|
||||
bool loadPeers();
|
||||
bool addPeer(const RsPeerDetails &pd);
|
||||
bool removePeer(std::string gpgId);
|
||||
bool savePeers();
|
||||
bool getPeersBeforeTS(time_t ts, std::list<std::string> &plist);
|
||||
|
||||
bool isValid(std::string gpgId);
|
||||
uint32_t getFlags(std::string gpgId);
|
||||
|
||||
private:
|
||||
|
||||
std::string mStoreFile;
|
||||
std::string mTempStoreFile;
|
||||
std::map<std::string, storeData> mGpgData;
|
||||
};
|
||||
|
||||
|
||||
|
||||
#endif
|
@ -1,6 +1,7 @@
|
||||
TEMPLATE = app
|
||||
TARGET = retroshare-nogui
|
||||
CONFIG += bitdht
|
||||
#CONFIG += introserver
|
||||
|
||||
################################# Linux ##########################################
|
||||
linux-* {
|
||||
@ -108,6 +109,11 @@ HEADERS += notifytxt.h
|
||||
SOURCES += notifytxt.cc \
|
||||
retroshare.cc
|
||||
|
||||
introserver {
|
||||
HEADERS += introserver.h
|
||||
SOURCES += introserver.cc
|
||||
DEFINES *= RS_INTRO_SERVER
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
@ -35,6 +35,9 @@
|
||||
#include <winsock2.h>
|
||||
#endif
|
||||
|
||||
#ifdef RS_INTRO_SERVER
|
||||
#include "introserver.h"
|
||||
#endif
|
||||
|
||||
/* Basic instructions for running libretroshare as background thread.
|
||||
* ******************************************************************* *
|
||||
@ -130,6 +133,10 @@ int main(int argc, char **argv)
|
||||
|
||||
/* Start-up libretroshare server threads */
|
||||
rsServer -> StartupRetroShare();
|
||||
|
||||
#ifdef RS_INTRO_SERVER
|
||||
RsIntroServer rsIS;
|
||||
#endif
|
||||
|
||||
/* pass control to the GUI */
|
||||
while(1)
|
||||
@ -140,6 +147,10 @@ int main(int argc, char **argv)
|
||||
#else
|
||||
Sleep(1000);
|
||||
#endif
|
||||
|
||||
#ifdef RS_INTRO_SERVER
|
||||
rsIS.tick();
|
||||
#endif
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user