示例#1
0
func (cr *Controller) UpdateMany(cx *goweb.Context) {
	log.Println("Update all diaries...")
	c := cr.db.C(COLLECTION)

	var diaries []*Diary
	decoder := new(goweb.JsonRequestDecoder)
	decoder.Unmarshal(cx, &diaries)

	if _, err := c.UpdateAll(nil, diaries); err != nil {
		log.Println("Error: %s", err.Error())
		cx.RespondWithError(http.StatusForbidden)
		return
	}

	log.Println("Updated all diaries")
	cx.ResponseWriter.Header().Set("Access-Control-Allow-Origin", "*")
	cx.RespondWithOK()
}
示例#2
0
func (cr *Controller) Create(cx *goweb.Context) {
	log.Println("Creating a diary...")
	c := cr.db.C(COLLECTION)

	var diary Diary
	decoder := new(goweb.JsonRequestDecoder)
	decoder.Unmarshal(cx, &diary)

	diary.Id = bson.NewObjectId().Hex()

	if err := c.Insert(&diary); err != nil {
		log.Println("Error: %s", err.Error())
		cx.RespondWithError(http.StatusForbidden)
		return
	}

	log.Printf("Created diary id=%s", diary.Id)
	cx.ResponseWriter.Header().Set("Access-Control-Allow-Origin", "*")
	cx.RespondWithData(diary.Id)
}
示例#3
0
func (cr *Controller) Update(id string, cx *goweb.Context) {
	log.Printf("Update a diary id=%s...", id)
	c := cr.db.C(COLLECTION)

	var diary *Diary
	decoder := new(goweb.JsonRequestDecoder)
	decoder.Unmarshal(cx, &diary)

	if err := c.UpdateId(id, diary); err != nil {
		log.Println("Error: %s", err.Error())
		cx.RespondWithError(http.StatusForbidden)
		return
	}

	log.Printf("Updated a diary id=%s", id)
	cx.ResponseWriter.Header().Set("Access-Control-Allow-Origin", "*")
	cx.ResponseWriter.Header().Set("Access-Control-Allow-Headers", "*")
	cx.ResponseWriter.Header().Set("Access-Control-Allow-Methods", "PUT,DELETE,POST,GET,OPTIONS")
	cx.RespondWithOK()
}