From 3d40d1266472ec5f0e8276e2c274641db3f21bc7 Mon Sep 17 00:00:00 2001 From: bassant ehab Date: Wed, 13 Aug 2025 23:09:17 +0000 Subject: [PATCH] getProvider function --- Makefile | 3 +++ examples/messaging/messages/getProvider.cpp | 15 +++++++++++++++ include/classes/Messaging.hpp | 7 ++++++- src/services/Messaging.cpp | 21 ++++++++++++++++++++- 4 files changed, 44 insertions(+), 2 deletions(-) create mode 100644 examples/messaging/messages/getProvider.cpp diff --git a/Makefile b/Makefile index b435495..0a345ab 100644 --- a/Makefile +++ b/Makefile @@ -254,6 +254,9 @@ getMessages: $(SRCS) $(EXAMPLES_DIR)/messaging/messages/getMessages.cpp createMessage: $(SRCS) $(EXAMPLES_DIR)/messaging/messages/createMessage.cpp @mkdir -p ./$(TESTS_DIR) $(CXX) $(CXXFLAGS) -o ./$(TESTS_DIR)/createMessage $(SRCS) $(EXAMPLES_DIR)/messaging/messages/createMessage.cpp $(LDFLAGS) +getProvider: $(SRCS) $(EXAMPLES_DIR)/messaging/messages/getProvider.cpp + @mkdir -p ./$(TESTS_DIR) + $(CXX) $(CXXFLAGS) -o ./$(TESTS_DIR)/getProvider $(SRCS) $(EXAMPLES_DIR)/messaging/messages/getProvider.cpp $(LDFLAGS) # Messaging - Topics getTopic: $(SRCS) $(EXAMPLES_DIR)/messaging/topics/getTopic.cpp diff --git a/examples/messaging/messages/getProvider.cpp b/examples/messaging/messages/getProvider.cpp new file mode 100644 index 0000000..9ba8a99 --- /dev/null +++ b/examples/messaging/messages/getProvider.cpp @@ -0,0 +1,15 @@ +#include "Appwrite.hpp" +#include +int main() { + std::string projectId = "68853010003a3f4fc106"; + std::string apiKey = ""; + std::string providerId = "689a4547001864da9330"; + try { + Messaging messaging(projectId, apiKey); + std::string response = messaging.getProvider(providerId); + std::cout << "provider Fetched!\nResponse: " << response << std::endl; + } catch (const AppwriteException &ex) { + std::cerr << "Exception: " << ex.what() << std::endl; + } + return 0; +} \ No newline at end of file diff --git a/include/classes/Messaging.hpp b/include/classes/Messaging.hpp index bc7c0bd..6fdc00b 100644 --- a/include/classes/Messaging.hpp +++ b/include/classes/Messaging.hpp @@ -174,7 +174,12 @@ class Messaging { const std::vector &topicId = {}, const std::vector &userId = {}); - + /** + * @brief Get a specific provider by ID. + * @param providerId ID of the provider + * @return JSON string of the provider details + */ + std::string getProvider(const std::string &providerId); private: std::string projectId; ///< Project ID std::string apiKey; ///< API Key diff --git a/src/services/Messaging.cpp b/src/services/Messaging.cpp index 13b8916..3bd15c8 100644 --- a/src/services/Messaging.cpp +++ b/src/services/Messaging.cpp @@ -528,4 +528,23 @@ std::string Messaging::updatePush(const std::string &messageId, "Error updating push message. Status code: " + std::to_string(statusCode) + "\n\nResponse: " + response); } -} \ No newline at end of file +} + +std::string Messaging::getProvider(const std::string &providerId) { + if (providerId.empty()) { + throw AppwriteException("Missing required parameter: providerId"); + } + std::string url = + Config::API_BASE_URL + "/messaging/providers/" + providerId; + std::vector headers = Config::getHeaders(projectId); + headers.push_back("X-Appwrite-Key: " + apiKey); + std::string response; + int statusCode = Utils::getRequest(url, headers, response); + if (statusCode == HttpStatus::OK) { + return response; + } else { + throw AppwriteException("Error fetching provider. Status code: " + + std::to_string(statusCode) + + "\nResponse: " + response); + } +}