🚧 working on endpoint for useranswer submit
Co-authored-by: haraldnilsen <harald_998@hotmail.com> Signed-off-by: Sindre Kjelsrud <kjelsrudsindre@gmail.com>
This commit is contained in:
		
							parent
							
								
									7ffea02700
								
							
						
					
					
						commit
						9f113c1258
					
				
					 5 changed files with 107 additions and 4 deletions
				
			
		|  | @ -11,13 +11,18 @@ import ( | |||
| 	"github.com/gin-gonic/gin" | ||||
| ) | ||||
| 
 | ||||
| type FormData struct { | ||||
| type UserformData struct { | ||||
|     Age                string `json:"age"` | ||||
|     Education          string `json:"education"` | ||||
|     HealthcarePersonnel bool  `json:"healthcare_personnel"` | ||||
|     Gender             string `json:"gender"` | ||||
| } | ||||
| 
 | ||||
| type FormData struct { | ||||
|     FormAnswers        string `json:"allFormAnswers"` | ||||
|     RespondentId       int `json:"respondentID"` | ||||
| } | ||||
| 
 | ||||
| func main() { | ||||
|     router := gin.Default() | ||||
|     router.Use(cors.Default()) | ||||
|  | @ -25,7 +30,7 @@ func main() { | |||
|     // Info about user | ||||
|     router.POST("/submituserform", func(c *gin.Context) { | ||||
| 
 | ||||
|         var requestBody FormData | ||||
|         var requestBody UserformData | ||||
| 
 | ||||
|         if err := c.BindJSON(&requestBody); err != nil { | ||||
|             fmt.Print(err) | ||||
|  | @ -71,6 +76,17 @@ func main() { | |||
|         if err := c.BindJSON(&requestBody); err != nil { | ||||
|             fmt.Print(err) | ||||
|         } | ||||
| 
 | ||||
|         respondentID, err := db.InsertUserAnswers(requestBody.RespondentId, requestBody.FormAnswers) | ||||
|          | ||||
|         if err != nil { | ||||
| 			fmt.Print(err) | ||||
| 			c.JSON(http.StatusInternalServerError, gin.H{"error": "Unable to insert data"}) | ||||
| 			return | ||||
| 		} | ||||
| 
 | ||||
|         // Respond with the ID of the newly inserted respondent | ||||
| 		c.JSON(http.StatusOK, gin.H{"respondentID": respondentID}) | ||||
|     }) | ||||
| 
 | ||||
|     // Run the server on port 8080 | ||||
|  |  | |||
							
								
								
									
										55
									
								
								backend/db/insert_user_answers.go
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								backend/db/insert_user_answers.go
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,55 @@ | |||
| package db | ||||
| 
 | ||||
| import ( | ||||
| 	"database/sql" | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"log" | ||||
| 
 | ||||
| 	_ "github.com/lib/pq" | ||||
| ) | ||||
| 
 | ||||
| func InsertUserAnswers(respondentId int, allAnswers string) (int, error) { | ||||
| 	// Parse allAnswers from JSON string to map | ||||
| 	var allAnswersArray []string | ||||
| 	err := json.Unmarshal([]byte(allAnswers), &allAnswersArray) | ||||
| 	if err != nil { | ||||
| 		return 0, fmt.Errorf("invalid JSON format for allAnswers: %v", err) | ||||
| 	} | ||||
| 
 | ||||
| 	// Connection string | ||||
| 	psqlInfo := fmt.Sprintf("host=%s port=%d user=%s "+ | ||||
| 		"password=%s dbname=%s sslmode=disable", | ||||
| 		host, port, user, password, dbname) | ||||
| 
 | ||||
| 	// Connect to the database | ||||
| 	db, err := sql.Open("postgres", psqlInfo) | ||||
| 	if err != nil { | ||||
| 		log.Fatalf("Error opening database: %v\n", err) | ||||
| 	} | ||||
| 	defer db.Close() | ||||
| 
 | ||||
| 	// Check the connection | ||||
| 	err = db.Ping() | ||||
| 	if err != nil { | ||||
| 		log.Fatalf("Error connecting to the database: %v\n", err) | ||||
| 	} | ||||
| 
 | ||||
| 	insertStatement := ` | ||||
| 	INSERT INTO SvarVurdering (svarID, respondentID, kunnskap, empati, hjelpsomhet) | ||||
| 	VALUES ($1, $2, $3, $4, $5) | ||||
| 	` | ||||
| 
 | ||||
| 	tx, err := db.Begin() | ||||
| 	if err != nil { | ||||
| 		log.Fatalf("Error creating transaction: %v\n", err) | ||||
| 	} | ||||
| 
 | ||||
| 	err = tx.Commit() | ||||
| 	if err != nil { | ||||
| 		log.Fatalf("Transaction commit failed: %v\n", err) | ||||
| 	} | ||||
| 
 | ||||
| 	fmt.Printf("Data inserted successfully for respondentID: %d\n", respondentId) | ||||
| 	return respondentId, nil | ||||
| } | ||||
		Reference in a new issue
	
	 Sindre Kjelsrud
						Sindre Kjelsrud