merged trunk commit 3225: restored the retroshare-nogui executable

git-svn-id: http://svn.code.sf.net/p/retroshare/code/branches/v0.5.0@3226 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
csoler 2010-06-27 16:32:50 +00:00
parent a00e311dd6
commit 7649a8d554
5 changed files with 95 additions and 65 deletions

View File

@ -173,6 +173,27 @@ bool RsInitConfig::udpListenerOnly;
static bool getAvailableAccounts(std::list<accountId> &ids);
static bool checkAccount(std::string accountdir, accountId &id);
static std::string toUpperCase(const std::string& s)
{
std::string res(s) ;
for(uint32_t i=0;i<res.size();++i)
if(res[i] > 96 && res[i] < 123)
res[i] -= 97-65 ;
return res ;
}
static std::string toLowerCase(const std::string& s)
{
std::string res(s) ;
for(uint32_t i=0;i<res.size();++i)
if(res[i] > 64 && res[i] < 91)
res[i] += 97-65 ;
return res ;
}
void RsInit::InitRsConfig()
{
@ -297,7 +318,7 @@ int RsInit::InitRetroShare(int argcIgnored, char **argvIgnored)
/******************************** WINDOWS/UNIX SPECIFIC PART ******************/
int c;
std::string prefPgpName = "";
std::string prefUserString = "";
/* getopt info: every availiable option is listed here. if it is followed by a ':' it
needs an argument. If it is followed by a '::' the argument is optional.
*/
@ -368,7 +389,7 @@ int RsInit::InitRetroShare(int argcIgnored, char **argvIgnored)
std::cerr << std::endl;
break;
case 'U':
prefPgpName = optarg;
prefUserString = optarg;
std::cerr << "Opt for User Id ";
std::cerr << std::endl;
break;
@ -385,10 +406,8 @@ int RsInit::InitRetroShare(int argcIgnored, char **argvIgnored)
std::cerr << "-a AutoLogin (Windows Only) + StartMinimised" << std::endl;
std::cerr << "-m StartMinimised" << std::endl;
std::cerr << "-u Only listen to UDP" << std::endl;
std::cerr << "-e Use a forwarded external Port" << std::endl << std::endl;
std::cerr << "-U [User Name] Sets Account to Use, Useful when Autologin is enabled" << std::endl;
std::cerr << "Example" << std::endl;
std::cerr << "./retroshare-nogui -wmysecretpassword -e" << std::endl;
std::cerr << "-e Use a forwarded external Port" << std::endl ;
std::cerr << "-U [User Name/GPG id/SSL id] Sets Account to Use, Useful when Autologin is enabled." << std::endl;
exit(1);
break;
default:
@ -488,22 +507,28 @@ int RsInit::InitRetroShare(int argcIgnored, char **argvIgnored)
// if a different user id has been passed to cmd line check for that instead
bool pgpNameFound = false;
if(prefPgpName != ""){
std::string lower_case_user_string = toLowerCase(prefUserString) ;
std::string upper_case_user_string = toUpperCase(prefUserString) ;
for(it = RsInitConfig::accountIds.begin() ; it!= RsInitConfig::accountIds.end() ; it++){
bool pgpNameFound = false;
if(prefUserString != "")
{
if(prefPgpName == it->pgpName){
for(it = RsInitConfig::accountIds.begin() ; it!= RsInitConfig::accountIds.end() ; it++)
{
std::cerr << "Checking account (gpgid = " << it->pgpId << ", name=" << it->pgpName << ", sslId=" << it->sslId << ")" << std::endl ;
RsInitConfig::preferedId = it->sslId;
pgpNameFound = true;
}
}
if(!pgpNameFound){
std::cerr << "Invalid User name -U pgpName not Found" << std::endl;
exit(1);
}
}
if(prefUserString == it->pgpName || upper_case_user_string == it->pgpId || lower_case_user_string == it->sslId)
{
RsInitConfig::preferedId = it->sslId;
pgpNameFound = true;
}
}
if(!pgpNameFound){
std::cerr << "Invalid User name/GPG id/SSL id: not found in list" << std::endl;
exit(1);
}
}

View File

@ -26,6 +26,7 @@
#include "notifytxt.h"
#include "rsiface/rspeers.h"
#include <string.h>
#include <iostream>
#include <sstream>
@ -40,18 +41,25 @@ void NotifyTxt::notifyChat()
return;
}
std::string NotifyTxt::askForPassword(const std::string& key_details,bool prev_is_bad)
{
char *password = getpass(("Please enter GPG password for key "+key_details+": ").c_str()) ;
return std::string(password);
}
void NotifyTxt::notifyListChange(int list, int type)
{
std::cerr << "NotifyTxt::notifyListChange()" << std::endl;
switch(list)
{
case NOTIFY_LIST_NEIGHBOURS:
displayNeighbours();
break;
// case NOTIFY_LIST_NEIGHBOURS:
// displayNeighbours();
// break;
case NOTIFY_LIST_FRIENDS:
displayFriends();
break;
case NOTIFY_LIST_DIRLIST:
case NOTIFY_LIST_DIRLIST_FRIENDS:
displayDirectories();
break;
case NOTIFY_LIST_SEARCHLIST:
@ -71,18 +79,16 @@ void NotifyTxt::notifyListChange(int list, int type)
}
return;
}
void NotifyTxt::displayNeighbours()
{
std::list<std::string> ids;
std::list<std::string> neighs;
std::list<std::string>::iterator it;
rsPeers->getOthersList(ids);
rsPeers->getGPGAllList(neighs);
std::ostringstream out;
for(it = ids.begin(); it != ids.end(); it++)
for(it = neighs.begin(); it != neighs.end(); it++)
{
RsPeerDetails detail;
rsPeers->getPeerDetails(*it, detail);

View File

@ -32,26 +32,27 @@
class NotifyTxt: public NotifyBase
{
public:
NotifyTxt() { return; }
virtual ~NotifyTxt() { return; }
void setRsIface(RsIface *i) { iface = i; }
public:
NotifyTxt() { return; }
virtual ~NotifyTxt() { return; }
void setRsIface(RsIface *i) { iface = i; }
virtual void notifyListChange(int list, int type);
virtual void notifyErrorMsg(int list, int sev, std::string msg);
virtual void notifyChat();
virtual void notifyListChange(int list, int type);
virtual void notifyErrorMsg(int list, int sev, std::string msg);
virtual void notifyChat();
virtual std::string askForPassword(const std::string& key_details,bool prev_is_bad) ;
private:
void displayNeighbours();
void displayFriends();
void displayDirectories();
void displaySearch();
void displayMessages();
void displayChannels();
void displayTransfers();
void displayNeighbours();
void displayFriends();
void displayDirectories();
void displaySearch();
void displayMessages();
void displayChannels();
void displayTransfers();
RsIface *iface; /* so we can get the data */
RsIface *iface; /* so we can get the data */
};
#endif

View File

@ -2,24 +2,26 @@ TEMPLATE = app
TARGET = retroshare-nogui
################################# Linux ##########################################
linux-* {
#CONFIG += version_detail_bash_script
QMAKE_CXXFLAGS *= -D_FILE_OFFSET_BITS=64
system(which gpgme-config >/dev/null 2>&1) {
INCLUDEPATH += $$system(gpgme-config --cflags | sed -e "s/-I//g")
} else {
message(Could not find gpgme-config on your system, assuming gpgme.h is in /usr/include)
}
LIBS += ../../libretroshare/src/lib/libretroshare.a
LIBS += -lssl -lgpgme -lupnp
}
linux-g++ {
OBJECTS_DIR = temp/linux-g++/obj
LIBS += ../../../../lib/linux-g++/libretroshare.a
LIBS += ../../../../lib/linux-g++/libminiupnpc.a
LIBS += ../../../../lib/linux-g++/libssl.a
LIBS += ../../../../lib/linux-g++/libcrypto.a
LIBS += -lpthread -lz
}
linux-g++-64 {
OBJECTS_DIR = temp/linux-g++-64/obj
LIBS += ../../../../lib/linux-g++-64/libretroshare.a
LIBS += ../../../../lib/linux-g++-64/libminiupnpc.a
LIBS += ../../../../lib/linux-g++-64/libssl.a
LIBS += ../../../../lib/linux-g++-64/libcrypto.a
LIBS += -lz
}
#################### Cross compilation for windows under Linux ###################

View File

@ -46,8 +46,6 @@
* The startup routine's are defined in rsiface.h
*/
RsControl *rsicontrol ;
int main(int argc, char **argv)
{
/* Retroshare startup is configured using an RsInit object.
@ -79,8 +77,6 @@ int main(int argc, char **argv)
* otherwise loaded from commandline.
*/
/* Key + Certificate are loaded into libretroshare */
RsInit::LoadCertificates(false);
/* Now setup the libretroshare interface objs
* You will need to create you own NotifyXXX class
@ -88,17 +84,17 @@ int main(int argc, char **argv)
NotifyTxt *notify = new NotifyTxt();
RsIface *iface = createRsIface(*notify);
RsControl *rsServer = createRsControl(*iface, *notify);
RsControl *rsServer = createRsControl(*iface, *notify);
rsicontrol = rsServer ;
notify->setRsIface(iface);
/* Key + Certificate are loaded into libretroshare */
RsInit::LoadCertificates(false);
/* Start-up libretroshare server threads */
rsServer -> StartupRetroShare();
rsicontrol = rsServer ;
RsInit::passwd = "" ;
//CleanupRsConfig(config);
/* pass control to the GUI */
while(1)