try to avoid nil point panic

This commit is contained in:
Sense T 2024-04-13 09:22:27 +08:00
parent 0012a697cb
commit 7b529ad8f6

View File

@ -10,8 +10,8 @@ import (
) )
func getRecords(c *gin.Context) { func getRecords(c *gin.Context) {
query := models.Record[models.RecordContentDefault]{} query := &models.Record[models.RecordContentDefault]{Content: make(models.RecordContentDefault)}
if err := c.BindQuery(&query); err != nil { if err := c.BindQuery(query); err != nil {
c.JSON(http.StatusBadRequest, Response{ c.JSON(http.StatusBadRequest, Response{
Succeed: false, Succeed: false,
Message: err.Error(), Message: err.Error(),
@ -21,7 +21,7 @@ func getRecords(c *gin.Context) {
domain := c.Param("domain") domain := c.Param("domain")
query.Zone = fmt.Sprintf("%s.", domain) query.Zone = fmt.Sprintf("%s.", domain)
records, err := controllers.GetRecords(&query) records, err := controllers.GetRecords(query)
if err != nil { if err != nil {
errorHandler(c, err) errorHandler(c, err)
return return
@ -34,7 +34,7 @@ func getRecords(c *gin.Context) {
} }
func createRecord(c *gin.Context) { func createRecord(c *gin.Context) {
record := &models.Record[models.RecordContentDefault]{} record := &models.Record[models.RecordContentDefault]{Content: make(models.RecordContentDefault)}
if err := c.BindJSON(record); err != nil { if err := c.BindJSON(record); err != nil {
c.JSON(http.StatusBadRequest, Response{ c.JSON(http.StatusBadRequest, Response{
Succeed: false, Succeed: false,
@ -65,7 +65,7 @@ func createRecord(c *gin.Context) {
} }
func createRecords(c *gin.Context) { func createRecords(c *gin.Context) {
var records []models.IRecord var records []models.Record[models.RecordContentDefault]
if err := c.BindJSON(&records); err != nil { if err := c.BindJSON(&records); err != nil {
c.JSON(http.StatusBadRequest, Response{ c.JSON(http.StatusBadRequest, Response{
Succeed: false, Succeed: false,
@ -74,7 +74,12 @@ func createRecords(c *gin.Context) {
return return
} }
if err := controllers.CreateRecords(records); err != nil { var iRecords []models.IRecord
for _, v := range records {
iRecords = append(iRecords, &v)
}
if err := controllers.CreateRecords(iRecords); err != nil {
errorHandler(c, err) errorHandler(c, err)
return return
} }
@ -85,7 +90,7 @@ func createRecords(c *gin.Context) {
} }
func updateRecord(c *gin.Context) { func updateRecord(c *gin.Context) {
record := &models.Record[models.RecordContentDefault]{} record := &models.Record[models.RecordContentDefault]{Content: make(models.RecordContentDefault)}
if err := c.BindJSON(record); err != nil { if err := c.BindJSON(record); err != nil {
c.JSON(http.StatusBadRequest, Response{ c.JSON(http.StatusBadRequest, Response{
Succeed: false, Succeed: false,