diff --git a/Makefile b/Makefile index e7742bf..c151b0c 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) listProviders: $(SRCS) $(EXAMPLES_DIR)/messaging/messages/listProviders.cpp @mkdir -p ./$(TESTS_DIR) $(CXX) $(CXXFLAGS) -o ./$(TESTS_DIR)/listProviders $(SRCS) $(EXAMPLES_DIR)/messaging/messages/listProviders.cpp $(LDFLAGS) @@ -262,11 +265,11 @@ listMessageLogs: $(SRCS) $(EXAMPLES_DIR)/messaging/messages/listMessageLogs.cpp $(CXX) $(CXXFLAGS) -o ./$(TESTS_DIR)/listMessageLogs $(SRCS) $(EXAMPLES_DIR)/messaging/messages/listMessageLogs.cpp $(LDFLAGS) deleteMessages: $(SRCS) $(EXAMPLES_DIR)/messaging/messages/deleteMessages.cpp @mkdir -p ./$(TESTS_DIR) - $(CXX) $(CXXFLAGS) -o ./$(TESTS_DIR)/deleteMessages $(SRCS) $(EXAMPLES_DIR)/messaging/messages/deleteMessages.cpp $(LDFLAGS) - + $(CXX) $(CXXFLAGS) -o ./$(TESTS_DIR)/deleteMessages $(SRCS) $(EXAMPLES_DIR)/messaging/messages/deleteMessages.cpp $(LDFLAGS) listTargets: $(SRCS) $(EXAMPLES_DIR)/messaging/messages/listTargets.cpp @mkdir -p ./$(TESTS_DIR) $(CXX) $(CXXFLAGS) -o ./$(TESTS_DIR)/listTargets $(SRCS) $(EXAMPLES_DIR)/messaging/messages/listTargets.cpp $(LDFLAGS) + # Messaging - Topics getTopic: $(SRCS) $(EXAMPLES_DIR)/messaging/topics/getTopic.cpp @mkdir -p ./$(TESTS_DIR) 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 d116771..480aab2 100644 --- a/include/classes/Messaging.hpp +++ b/include/classes/Messaging.hpp @@ -181,6 +181,13 @@ class Messaging { */ std::string listProviders(Queries &queries); + /** + * @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); + /** * @brief List all message logs with optional filters. * @param messageId ID of the message diff --git a/src/services/Messaging.cpp b/src/services/Messaging.cpp index 9ddd6a0..6dfc1b2 100644 --- a/src/services/Messaging.cpp +++ b/src/services/Messaging.cpp @@ -530,6 +530,25 @@ std::string Messaging::updatePush(const std::string &messageId, } } +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); + } +} + std::string Messaging::listProviders(Queries &queries) { std::string url = Config::API_BASE_URL + "/messaging/providers"; std::vector headers = Config::getHeaders(projectId); @@ -611,4 +630,5 @@ std::string Messaging::listTargets(const std::string &messageId, "Error fetching message targets. Status code: " + std::to_string(statusCode) + "\n\nResponse: " + response); } -} \ No newline at end of file +} +