summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorOleg Morozenkov <m@oleg.rocks>2020-11-10 19:07:38 +0300
committerGitHub <noreply@github.com>2020-11-10 19:07:38 +0300
commit9dae1b4ae78218a7ebd341f8b2952fe26affdf74 (patch)
tree0e4013ed935ff9dd0b1c117cad4fd31aeb22ce1c
parentbd70cd3c5206d7c10092f8abb0d07d653b8ce14c (diff)
parent0bf49aa347de2512370c96aef7b5477423f14318 (diff)
Merge pull request #157 from nesc1/customizeServerUrl
Add support to configure the API bot server url
-rw-r--r--include/tgbot/Api.h3
-rw-r--r--include/tgbot/Bot.h2
-rw-r--r--src/Api.cpp10
-rw-r--r--src/Bot.cpp4
4 files changed, 11 insertions, 8 deletions
diff --git a/include/tgbot/Api.h b/include/tgbot/Api.h
index e48da6f..1adbbe5 100644
--- a/include/tgbot/Api.h
+++ b/include/tgbot/Api.h
@@ -46,7 +46,7 @@ typedef std::shared_ptr<std::vector<std::string>> StringArrayPtr;
friend class Bot;
public:
- Api(std::string token, const HttpClient& httpClient);
+ Api(std::string token, const HttpClient& httpClient, const std::string& url);
/**
* @brief A simple method for testing your bot's auth token.
@@ -823,6 +823,7 @@ private:
const std::string _token;
const HttpClient& _httpClient;
const TgTypeParser _tgTypeParser;
+ const std::string _url;
};
}
diff --git a/include/tgbot/Bot.h b/include/tgbot/Bot.h
index 023a71b..36d3cb4 100644
--- a/include/tgbot/Bot.h
+++ b/include/tgbot/Bot.h
@@ -21,7 +21,7 @@ class HttpClient;
class TGBOT_API Bot {
public:
- explicit Bot(std::string token, const HttpClient &httpClient = _getDefaultHttpClient());
+ explicit Bot(std::string token, const HttpClient &httpClient = _getDefaultHttpClient(), const std::string& url="https://api.telegram.org");
/**
* @return Token for accessing api.
diff --git a/src/Api.cpp b/src/Api.cpp
index 0a08353..9acf1bb 100644
--- a/src/Api.cpp
+++ b/src/Api.cpp
@@ -15,8 +15,8 @@ using namespace boost::property_tree;
namespace TgBot {
-Api::Api(string token, const HttpClient& httpClient)
- : _token(std::move(token)), _httpClient(httpClient), _tgTypeParser() {
+Api::Api(string token, const HttpClient& httpClient, const std::string& url)
+ : _token(std::move(token)), _httpClient(httpClient), _tgTypeParser(), _url(url) {
}
User::Ptr Api::getMe() const {
@@ -1172,7 +1172,8 @@ std::vector<BotCommand::Ptr> Api::getMyCommands() const
}
ptree Api::sendRequest(const string& method, const vector<HttpReqArg>& args) const {
- string url = "https://api.telegram.org/bot";
+ string url(_url);
+ url += "/bot";
url += _token;
url += "/";
url += method;
@@ -1195,7 +1196,8 @@ ptree Api::sendRequest(const string& method, const vector<HttpReqArg>& args) con
}
string Api::downloadFile(const string& filePath, const std::vector<HttpReqArg>& args) const {
- string url = "https://api.telegram.org/file/bot";
+ string url(_url);
+ url += "/file/bot";
url += _token;
url += "/";
url += filePath;
diff --git a/src/Bot.cpp b/src/Bot.cpp
index 11bea2c..080b9a2 100644
--- a/src/Bot.cpp
+++ b/src/Bot.cpp
@@ -8,9 +8,9 @@
namespace TgBot {
-Bot::Bot(std::string token, const HttpClient& httpClient)
+Bot::Bot(std::string token, const HttpClient& httpClient, const std::string& url)
: _token(std::move(token))
- , _api(_token, httpClient)
+ , _api(_token, httpClient, url)
, _eventBroadcaster(std::make_unique<EventBroadcaster>())
, _eventHandler(getEvents()) {
}