mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-07 05:38:09 -05:00
55653325d1
git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@1055 b45a01b8-16f6-495d-af2f-9b41ad6348cc
119 lines
3.4 KiB
C++
119 lines
3.4 KiB
C++
|
|
/*
|
|
* "$Id: retroshare.cc,v 1.4 2007-04-21 19:08:51 rmf24 Exp $"
|
|
*
|
|
* RetroShare C++ Interface.
|
|
*
|
|
* Copyright 2004-2006 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 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 "rsiface/rsiface.h" /* definition of iface */
|
|
#include "rsiface/rsinit.h" /* definition of iface */
|
|
|
|
#include "notifytxt.h"
|
|
|
|
#include <iostream>
|
|
#ifdef WINDOWS_SYS
|
|
#include <winsock2.h>
|
|
#endif
|
|
|
|
|
|
/* Basic instructions for running libretroshare as background thread.
|
|
* ******************************************************************* *
|
|
* This allows your program to communicate with authenticated peers.
|
|
*
|
|
* libretroshare's interfaces are defined in libretroshare/src/rsiface.
|
|
* This should be the only headers that you need to include.
|
|
*
|
|
* 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.
|
|
* This is an opaque class, which the user cannot directly tweak
|
|
* If you want to peek at whats happening underneath look in
|
|
* libretroshare/src/rsserver/p3face-startup.cc
|
|
*
|
|
* You create it with InitRsConfig(), and delete with CleanupRsConfig()
|
|
* InitRetroshare(argv, argc, config) parses the command line options,
|
|
* and initialises the config paths.
|
|
*
|
|
* *** There are several functions that I should add to modify
|
|
* **** the config the moment these can only be set via the commandline
|
|
* - RsConfigDirectory(...) is probably the most useful.
|
|
* - RsConfigNetAddr(...) for setting port, etc.
|
|
* - RsConfigOutput(...) for logging and debugging.
|
|
*
|
|
* Next you need to worry about loading your certificate, or making
|
|
* a new one:
|
|
*
|
|
* RsGenerateCertificate(...) To create a new key, certificate
|
|
* LoadPassword(...) set password for existing certificate.
|
|
**/
|
|
|
|
RsInit::InitRsConfig();
|
|
RsInit::InitRetroShare(argc, argv);
|
|
|
|
/* load password should be called at this point: LoadPassword()
|
|
* 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
|
|
* if you want to receive notifications of events */
|
|
|
|
NotifyTxt *notify = new NotifyTxt();
|
|
RsIface *iface = createRsIface(*notify);
|
|
RsControl *rsServer = createRsControl(*iface, *notify);
|
|
|
|
notify->setRsIface(iface);
|
|
|
|
/* Start-up libretroshare server threads */
|
|
|
|
rsServer -> StartupRetroShare();
|
|
|
|
rsicontrol = rsServer ;
|
|
RsInit::passwd = "" ;
|
|
//CleanupRsConfig(config);
|
|
|
|
/* pass control to the GUI */
|
|
while(1)
|
|
{
|
|
std::cerr << "GUI Tick()" << std::endl;
|
|
#ifndef WINDOWS_SYS
|
|
sleep(1);
|
|
#else
|
|
Sleep(1000);
|
|
#endif
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
|
|
|
|
|