forked from Ailur/burgernotes-server
Add /api/purgenotes
This commit is contained in:
parent
8d97cb2d0a
commit
8e1b3eaec9
|
@ -72,13 +72,16 @@ POST - /api/editnote - edit notes, provide "secretKey", "noteId", "title", and "
|
||||||
|
|
||||||
POST - /api/removenote - remove notes, provide "secretKey" and "noteId"
|
POST - /api/removenote - remove notes, provide "secretKey" and "noteId"
|
||||||
|
|
||||||
## ⚙️ Account managment
|
POST - /api/purgenotes - remove all notes, provide "secretKey"
|
||||||
|
### Please display a warning before this action
|
||||||
|
|
||||||
|
## ⚙️ Account management
|
||||||
|
|
||||||
POST - /api/changepassword - change account password, provide "secretKey", "newPassword"
|
POST - /api/changepassword - change account password, provide "secretKey", "newPassword"
|
||||||
encrypt the same way as /api/login
|
encrypt the same way as /api/login
|
||||||
|
|
||||||
POST - /api/deleteaccount - delete account, provide "secretKey"
|
POST - /api/deleteaccount - delete account, provide "secretKey"
|
||||||
please display a warning before this action
|
### Please display a warning before this action
|
||||||
|
|
||||||
POST - /api/exportnotes - export notes, provide "secretKey"
|
POST - /api/exportnotes - export notes, provide "secretKey"
|
||||||
note content and title will have to be decrypted
|
note content and title will have to be decrypted
|
||||||
|
|
30
main.go
30
main.go
|
@ -1004,6 +1004,36 @@ func main() {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
router.POST("/api/purgenotes", func(c *gin.Context) {
|
||||||
|
var data map[string]interface{}
|
||||||
|
err := c.ShouldBindJSON(&data)
|
||||||
|
if err != nil {
|
||||||
|
c.JSON(400, gin.H{"error": "Invalid JSON"})
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
token, ok := data["secretKey"].(string)
|
||||||
|
if !ok {
|
||||||
|
c.JSON(400, gin.H{"error": "Invalid JSON"})
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
_, userid, err := getSession(token)
|
||||||
|
if err != nil {
|
||||||
|
c.JSON(401, gin.H{"error": "Invalid session"})
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = conn.Exec("DELETE FROM notes WHERE creator = ?", userid)
|
||||||
|
if err != nil {
|
||||||
|
log.Println("[ERROR] Unknown in /api/purgenotes Exec() at", strconv.FormatInt(time.Now().Unix(), 10)+":", err)
|
||||||
|
c.JSON(500, gin.H{"error": "Something went wrong on our end. Please report this bug at https://centrifuge.hectabit.org/hectabit/burgernotes and refer to the documentation for more info. Your error code is: UNKNOWN-API-PURGENOTES-DBDELETE"})
|
||||||
|
return
|
||||||
|
} else {
|
||||||
|
c.JSON(200, gin.H{"success": true})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
router.POST("/api/editnote", func(c *gin.Context) {
|
router.POST("/api/editnote", func(c *gin.Context) {
|
||||||
var data map[string]interface{}
|
var data map[string]interface{}
|
||||||
err := c.ShouldBindJSON(&data)
|
err := c.ShouldBindJSON(&data)
|
||||||
|
|
Loading…
Reference in New Issue