func (this *OrganizationWebV1Controller) PostOrg() { user := new(models.User) org := new(models.Organization) if exist, _, err := user.Has(this.Ctx.Input.Param(":username")); err != nil { this.JSONOut(http.StatusBadRequest, err.Error(), nil) return } else if exist == false { this.JSONOut(http.StatusBadRequest, "User not exist", nil) return } if exist, _, err := user.Has(this.Ctx.Input.Param(":org")); err != nil { this.JSONOut(http.StatusBadRequest, err.Error(), nil) return } else if exist == true { this.JSONOut(http.StatusBadRequest, "Namespace is occupation already by another user", nil) return } if exist, _, err := org.Has(this.Ctx.Input.Param(":org")); err != nil { this.JSONOut(http.StatusBadRequest, err.Error(), nil) return } else if exist == true { this.JSONOut(http.StatusBadRequest, "Namespace is occupation already by another organization", nil) return } if err := json.Unmarshal(this.Ctx.Input.CopyBody(), &org); err != nil { this.JSONOut(http.StatusBadRequest, err.Error(), nil) return } org.Id = string(utils.GeneralKey(org.Name)) org.Username = user.Username org.Created = time.Now().UnixNano() / int64(time.Millisecond) org.Updated = time.Now().UnixNano() / int64(time.Millisecond) if err := org.Save(); err != nil { this.JSONOut(http.StatusBadRequest, "Organization save error", nil) return } user.Organizations = append(user.Organizations, org.Name) user.Updated = time.Now().UnixNano() / int64(time.Millisecond) if err := user.Save(); err != nil { this.JSONOut(http.StatusBadRequest, "User save error", nil) return } memo, _ := json.Marshal(this.Ctx.Input.Header) user.Log(models.ACTION_ADD_ORG, models.LEVELINFORMATIONAL, models.TYPE_WEBV1, org.Id, memo) org.Log(models.ACTION_ADD_ORG, models.LEVELINFORMATIONAL, models.TYPE_WEBV1, user.Id, memo) this.JSONOut(http.StatusOK, "Create organization successfully.", nil) return }