From 2e4cd879b2f3f80a9d74e86086af07bb26e21d35 Mon Sep 17 00:00:00 2001 From: Vargha Csongor Date: Tue, 16 Apr 2024 22:26:55 +0200 Subject: [PATCH] delete relationship --- backend/handlers/deleteRelationship.go | 31 ++++++++++++++++++++++ backend/memgraph/deleteRelationship.go | 36 ++++++++++++++++++++++++++ 2 files changed, 67 insertions(+) create mode 100644 backend/memgraph/deleteRelationship.go diff --git a/backend/handlers/deleteRelationship.go b/backend/handlers/deleteRelationship.go index 5ac8282..97a12bf 100644 --- a/backend/handlers/deleteRelationship.go +++ b/backend/handlers/deleteRelationship.go @@ -1 +1,32 @@ package handlers + +import ( + "log" + "net/http" + + "github.com/gin-gonic/gin" + "github.com/neo4j/neo4j-go-driver/v5/neo4j" + "github.com/vcscsvcscs/GenerationsHeritage/backend/memgraph" +) + +func DelteRelationship(driver neo4j.DriverWithContext) gin.HandlerFunc { + return func(c *gin.Context) { + var relationship memgraph.Relationship + if err := c.ShouldBindJSON(&relationship); err != nil { + log.Printf("ip: %s error: %s", c.ClientIP(), err) + c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()}) + + return + } + + err := relationship.DeleteRelationship(driver) + if err != nil { + log.Printf("ip: %s error: %s", c.ClientIP(), err) + c.JSON(http.StatusInternalServerError, gin.H{"error": "internal server error"}) + + return + } + + c.JSON(http.StatusAccepted, gin.H{"status": "relationship deleted successfully"}) + } +} diff --git a/backend/memgraph/deleteRelationship.go b/backend/memgraph/deleteRelationship.go new file mode 100644 index 0000000..c59943c --- /dev/null +++ b/backend/memgraph/deleteRelationship.go @@ -0,0 +1,36 @@ +package memgraph + +import ( + "fmt" + "time" + + "github.com/neo4j/neo4j-go-driver/v5/neo4j" + "golang.org/x/net/context" +) + +func (r *Relationship) DeleteRelationship(driver neo4j.DriverWithContext) error { + ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second) + defer cancel() + + session := driver.NewSession(ctx, neo4j.SessionConfig{AccessMode: neo4j.AccessModeRead}) + defer session.Close(ctx) + + if err := r.Verify(); err != nil { + return err + } + + query := "" + if r.Direction == "->" { + query = fmt.Sprintf(`MATCH (a)-[r:%s]->(b)`, r.Relationship) + } else if r.Direction == "<-" { + query = fmt.Sprintf(`MATCH (a)<-[r:%s]-(b)`, r.Relationship) + } else { + query = fmt.Sprintf(`MATCH (a)-[r:%s]-(b)`, r.Relationship) + } + + query = fmt.Sprintf(`%s WHERE a.ID = %s AND b.ID = %s DELETE r;`, query, r.FirstPersonID, r.SecondPersonID) + + _, err := session.Run(ctx, query, nil) + + return err +}