From cda4df04d6290e71ab88c2a99c4d80badaaf828e Mon Sep 17 00:00:00 2001
From: Emanuel <Emanuel.Petrinovic@Student.Reutlingen-University.DE>
Date: Mon, 14 Apr 2025 13:46:26 +0200
Subject: [PATCH] get campaigns

---
 src/myaktion/handler/campaign.go | 14 ++++++++++++++
 src/myaktion/main.go             |  1 +
 src/myaktion/service/campaign.go | 11 +++++++++++
 3 files changed, 26 insertions(+)

diff --git a/src/myaktion/handler/campaign.go b/src/myaktion/handler/campaign.go
index 5caad3b..95b2934 100644
--- a/src/myaktion/handler/campaign.go
+++ b/src/myaktion/handler/campaign.go
@@ -28,3 +28,17 @@ func CreateCampaign(w http.ResponseWriter, r *http.Request) {
 		http.Error(w, err.Error(), http.StatusInternalServerError)
 	}
 }
+
+func GetCampaigns(w http.ResponseWriter, _ *http.Request) {
+	campaigns, err := service.GetCampaigns()
+	if err != nil {
+		log.Printf("Error calling service GetCampaigns: %v", err)
+		http.Error(w, err.Error(), http.StatusInternalServerError)
+		return
+	}
+	w.Header().Set("Content-Type", "application/json")
+	if err := json.NewEncoder(w).Encode(campaigns); err != nil {
+		log.Printf("Failure encoding value to JSON: %v", err)
+		http.Error(w, err.Error(), http.StatusInternalServerError)
+	}
+}
diff --git a/src/myaktion/main.go b/src/myaktion/main.go
index 13a3654..bbb8e89 100644
--- a/src/myaktion/main.go
+++ b/src/myaktion/main.go
@@ -13,6 +13,7 @@ func main() {
 	router := mux.NewRouter()
 	router.HandleFunc("/health", handler.Health).Methods("GET")
 	router.HandleFunc("/campaigns", handler.CreateCampaign).Methods("POST")
+	router.HandleFunc("/campaigns", handler.GetCampaigns).Methods("GET")
 	if err := http.ListenAndServe(":8000", router); err != nil {
 		log.Fatal(err)
 	}
diff --git a/src/myaktion/service/campaign.go b/src/myaktion/service/campaign.go
index d8b4456..5cac517 100644
--- a/src/myaktion/service/campaign.go
+++ b/src/myaktion/service/campaign.go
@@ -26,3 +26,14 @@ func CreateCampaign(campaign *model.Campaign) error {
 	return nil
 
 }
+
+func GetCampaigns() ([]model.Campaign, error) {
+	var campaigns []model.Campaign
+
+	for _, campaign := range campaginStore {
+		campaigns = append(campaigns, *campaign)
+	}
+	log.Printf("Retrieved: %v", campaigns)
+
+	return campaigns, nil
+}
-- 
GitLab