Browse Source

Adding more to the option parser.

Adding instruction on how to test it.
pull/19/head
Meeh 11 years ago
parent
commit
633c9becd9
  1. 30
      README.md
  2. 5
      i2p.cpp
  3. 8
      util.cpp
  4. 3
      util.h

30
README.md

@ -8,3 +8,33 @@ Requires gcc 4.6 and higher, boost 1.46 and higher, crypto++ @@ -8,3 +8,33 @@ Requires gcc 4.6 and higher, boost 1.46 and higher, crypto++
on Windows
Requires msvs2013, boost 1.46 and higher, crypto++
Testing
-------
First, build it.
$ cd i2pd
$ make
Now, copy your netDb folder from your Java I2P config dir. (The one with r0, r1, r2, ... folders in it) to the source folder where your i2p binary is.
Next, find out your public ip. (find it for example at http://www.whatismyip.com/)
Then, run it with:
$ ./i2p --host=YOUR_PUBLIC_IP
Other options:
--port= - The port to listen on
--httpport= - The http port to listen on
To visit an I2P page, you need to find the b32 address of your destination.
After that, go to the webconsole and add it behind the url. (Remove http:// and b32.i2p from the address)
This should resulting in for example:
http://localhost:7070/4oes3rlgrpbkmzv4lqcfili23h3cvpwslqcfjlk6vvguxyggspwa

5
i2p.cpp

@ -14,7 +14,7 @@ @@ -14,7 +14,7 @@
int main( int argc, char* argv[] )
{
i2p::util::ParseArguments(argc,argv);
i2p::util::OptionParser(argc,argv);
#ifdef _WIN32
setlocale(LC_CTYPE, "");
SetConsoleCP(1251);
@ -22,6 +22,9 @@ int main( int argc, char* argv[] ) @@ -22,6 +22,9 @@ int main( int argc, char* argv[] )
setlocale(LC_ALL, "Russian");
#endif
//TODO: This is an ugly workaround. fix it.
//TODO: Autodetect public IP.
i2p::context.OverrideNTCPAddress(i2p::util::GetCharArg("--host", "127.0.0.1"), i2p::util::GetIntArg("--port", 17070));
int httpport = i2p::util::GetIntArg("--httpport", 7070);
i2p::util::HTTPServer httpServer (httpport);

8
util.cpp

@ -6,7 +6,7 @@ namespace util @@ -6,7 +6,7 @@ namespace util
{
std::map<std::string, std::string> mapArgs;
void ParseArguments(int argc, const char* const argv[])
void OptionParser(int argc, const char* const argv[])
{
mapArgs.clear();
for (int i = 1; i < argc; i++)
@ -33,11 +33,11 @@ int GetIntArg(const std::string& strArg, int nDefault) @@ -33,11 +33,11 @@ int GetIntArg(const std::string& strArg, int nDefault)
return nDefault;
}
std::string GetStringArg(const std::string& strArg, std::string nDefault)
const char* GetCharArg(const std::string& strArg, const std::string& nDefault)
{
if (mapArgs.count(strArg))
return mapArgs[strArg];
return nDefault;
return mapArgs[strArg].c_str();
return nDefault.c_str();
}

3
util.h

@ -9,8 +9,9 @@ namespace i2p @@ -9,8 +9,9 @@ namespace i2p
namespace util
{
extern std::map<std::string, std::string> mapArgs;
void ParseArguments(int argc, const char* const argv[]);
void OptionParser(int argc, const char* const argv[]);
int GetIntArg(const std::string& strArg, int nDefault);
const char* GetCharArg(const std::string& strArg, const std::string& nDefault);
}
}

Loading…
Cancel
Save