diff options
author | Oleg Morozenkov <m@oleg.rocks> | 2020-11-10 19:07:38 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-11-10 19:07:38 +0300 |
commit | 9dae1b4ae78218a7ebd341f8b2952fe26affdf74 (patch) | |
tree | 0e4013ed935ff9dd0b1c117cad4fd31aeb22ce1c | |
parent | bd70cd3c5206d7c10092f8abb0d07d653b8ce14c (diff) | |
parent | 0bf49aa347de2512370c96aef7b5477423f14318 (diff) |
Merge pull request #157 from nesc1/customizeServerUrl
Add support to configure the API bot server url
-rw-r--r-- | include/tgbot/Api.h | 3 | ||||
-rw-r--r-- | include/tgbot/Bot.h | 2 | ||||
-rw-r--r-- | src/Api.cpp | 10 | ||||
-rw-r--r-- | src/Bot.cpp | 4 |
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()) { } |