本文整理汇总了Golang中github.com/containerops/wharf/models.User类的典型用法代码示例。如果您正苦于以下问题:Golang User类的具体用法?Golang User怎么用?Golang User使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了User类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: GetUsers
func (this *UserWebAPIV1Controller) GetUsers() {
user := new(models.User)
users := user.All()
this.JSONOut(http.StatusOK, "", users)
return
}
示例2: GetJoinOrgs
func (this *OrganizationWebV1Controller) GetJoinOrgs() {
user := new(models.User)
orgs := make([]models.Organization, 0)
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
}
for _, name := range user.JoinOrganizations {
org := new(models.Organization)
if err := org.GetByName(name); err != nil {
this.JSONOut(http.StatusBadRequest, "Get organizations error", nil)
return
}
orgs = append(orgs, *org)
}
this.JSONOut(http.StatusOK, "", orgs)
return
}
示例3: PutRepository
func (this *RepoAPIV1Controller) PutRepository() {
username, _, _ := utils.DecodeBasicAuth(this.Ctx.Input.Header("Authorization"))
namespace := string(this.Ctx.Input.Param(":namespace"))
repository := string(this.Ctx.Input.Param(":repo_name"))
repo := new(models.Repository)
if err := repo.Put(namespace, repository, string(this.Ctx.Input.CopyBody()), this.Ctx.Input.Header("User-Agent"), models.APIVERSION_V1); err != nil {
this.JSONOut(http.StatusForbidden, err.Error(), nil)
return
}
if this.Ctx.Input.Header("X-Docker-Token") == "true" {
token := string(utils.GeneralKey(username))
this.SetSession("token", token)
this.Ctx.Output.Context.ResponseWriter.Header().Set("X-Docker-Token", token)
this.Ctx.Output.Context.ResponseWriter.Header().Set("WWW-Authenticate", token)
}
user := new(models.User)
if _, _, err := user.Has(username); err != nil {
this.JSONOut(http.StatusForbidden, err.Error(), nil)
return
}
memo, _ := json.Marshal(this.Ctx.Input.Header)
user.Log(models.ACTION_UPDATE_REPO, models.LEVELINFORMATIONAL, models.TYPE_APIV1, repo.Id, memo)
repo.Log(models.ACTION_UPDATE_REPO, models.LEVELINFORMATIONAL, models.TYPE_APIV1, repo.Id, memo)
this.Ctx.Output.Context.ResponseWriter.Header().Set("X-Docker-Endpoints", beego.AppConfig.String("docker::Endpoints"))
this.Ctx.Output.Context.Output.SetStatus(http.StatusOK)
this.Ctx.Output.Context.Output.Body([]byte(""))
return
}
示例4: GetTeams
func (this *OrganizationWebV1Controller) GetTeams() {
user := new(models.User)
teams := make([]models.Team, 0)
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
}
for _, name := range user.Teams {
team := new(models.Team)
if exist, _, err := team.Has(strings.Split(name, "-")[0], strings.Split(name, "-")[1]); err != nil {
this.JSONOut(http.StatusBadRequest, "Get Team error", nil)
return
} else if exist == false {
this.JSONOut(http.StatusBadRequest, "Team invalid", nil)
return
}
teams = append(teams, *team)
}
this.JSONOut(http.StatusOK, "", teams)
return
}
示例5: GetTeam
func (this *OrganizationWebV1Controller) GetTeam() {
user := new(models.User)
org := new(models.Organization)
team := new(models.Team)
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 := org.Has(this.Ctx.Input.Param(":org")); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
} else if exist == false {
this.JSONOut(http.StatusBadRequest, "Organization not exist", nil)
return
}
if exist, _, err := team.Has(this.Ctx.Input.Param(":org"), this.Ctx.Input.Param(":team")); err != nil {
this.JSONOut(http.StatusBadRequest, "Search team error", nil)
return
} else if exist == false {
this.JSONOut(http.StatusBadRequest, "Team not exist", nil)
return
}
this.JSONOut(http.StatusOK, "", team)
return
}
示例6: PutPassword
func (this *UserWebAPIV1Controller) PutPassword() {
user := new(models.User)
var p map[string]interface{}
if err := json.Unmarshal(this.Ctx.Input.CopyBody(), &p); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
}
if exist, _, err := user.Has(this.Ctx.Input.Param(":username")); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
} else if exist == false && err == nil {
this.JSONOut(http.StatusBadRequest, "Search user error", nil)
return
} else if p["oldPassword"].(string) != user.Password {
this.JSONOut(http.StatusBadRequest, "account and password not match", nil)
return
}
user.Password = p["newPassword"].(string)
user.Updated = time.Now().UnixNano() / int64(time.Millisecond)
if err := user.Save(); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
}
memo, _ := json.Marshal(this.Ctx.Input.Header)
user.Log(models.ACTION_UPDATE_PASSWORD, models.LEVELINFORMATIONAL, models.TYPE_WEBV1, user.Id, memo)
this.JSONOut(http.StatusOK, "Update password success!", nil)
return
}
示例7: PutTeamAddMember
func (this *TeamWebV1Controller) PutTeamAddMember() {
if _, exist := this.Ctx.Input.CruSession.Get("user").(models.User); exist == false {
this.JSONOut(http.StatusBadRequest, "", map[string]string{"message": "Session load failure", "url": "/auth"})
return
}
org := new(models.Organization)
if err := org.GetByName(this.Ctx.Input.Param(":org")); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
}
team := new(models.Team)
if err := team.GetByName(this.Ctx.Input.Param(":org"), this.Ctx.Input.Param(":team")); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
}
user := new(models.User)
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 found", nil)
return
}
exist := false
for _, u := range team.Users {
if u == this.Ctx.Input.Param(":username") {
exist = true
}
}
if exist == true {
this.JSONOut(http.StatusBadRequest, "User already in team", nil)
return
} else {
team.Users = append(team.Users, this.Ctx.Input.Param(":username"))
if err := team.Save(); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
}
this.JSONOut(http.StatusOK, "", user)
return
}
}
示例8: GetUser
func (this *UserWebAPIV1Controller) GetUser() {
user := new(models.User)
if exist, _, err := user.Has(this.Ctx.Input.Param(":username")); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
} else if exist == false && err == nil {
this.JSONOut(http.StatusBadRequest, "Search user error", nil)
return
}
user.Password = "xxxxxx"
this.JSONOut(http.StatusOK, "", user)
return
}
示例9: PutTeam
func (this *OrganizationWebV1Controller) PutTeam() {
user := new(models.User)
org := new(models.Organization)
team := new(models.Team)
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 := org.Has(this.Ctx.Input.Param(":org")); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
} else if exist == false {
this.JSONOut(http.StatusBadRequest, "Organization not exist", nil)
return
}
if exist, _, err := team.Has(this.Ctx.Input.Param(":org"), this.Ctx.Input.Param(":team")); err != nil {
this.JSONOut(http.StatusBadRequest, "Search team error", nil)
return
} else if exist == false {
this.JSONOut(http.StatusBadRequest, "Team not exist", nil)
return
}
if err := json.Unmarshal(this.Ctx.Input.CopyBody(), &team); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
}
team.Updated = time.Now().UnixNano() / int64(time.Millisecond)
if err := team.Save(); err != nil {
this.JSONOut(http.StatusBadRequest, "Team save error", nil)
return
}
this.JSONOut(http.StatusOK, "Team update successfully", nil)
return
}
示例10: GetNamespaces
func (this *UserWebAPIV1Controller) GetNamespaces() {
user := new(models.User)
if exist, _, err := user.Has(this.Ctx.Input.Param(":username")); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
} else if exist == false && err == nil {
this.JSONOut(http.StatusBadRequest, "Search user error", nil)
return
} else {
namespaces := make([]string, 0)
namespaces = append(namespaces, user.Username)
namespaces = append(namespaces, user.Organizations...)
this.JSONOut(http.StatusOK, "", namespaces)
return
}
}
示例11: GetUsers
//There is nothing in request body, just authorization through Basic Authorization.
func (this *UserAPIV1Controller) GetUsers() {
if username, passwd, err := utils.DecodeBasicAuth(this.Ctx.Input.Header("Authorization")); err != nil {
this.JSONOut(http.StatusUnauthorized, err.Error(), nil)
return
} else {
user := new(models.User)
if err := user.Get(username, passwd); err != nil {
this.JSONOut(http.StatusUnauthorized, err.Error(), nil)
return
}
memo, _ := json.Marshal(this.Ctx.Input.Header)
user.Log(models.ACTION_SIGNUP, models.LEVELINFORMATIONAL, models.TYPE_APIV1, user.Id, memo)
this.JSONOut(http.StatusOK, "User authorization successfully.", nil)
return
}
}
示例12: Signin
func (this *UserWebAPIV1Controller) Signin() {
user := new(models.User)
if err := json.Unmarshal(this.Ctx.Input.CopyBody(), &user); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
} else {
if err := user.Get(user.Username, user.Password); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
}
memo, _ := json.Marshal(this.Ctx.Input.Header)
user.Log(models.ACTION_SIGNIN, models.LEVELINFORMATIONAL, models.TYPE_WEBV1, user.Id, memo)
this.Ctx.Input.CruSession.Set("user", user)
this.JSONOut(http.StatusOK, "User singin successfully!", nil)
return
}
}
示例13: Signup
func (this *UserWebAPIV1Controller) Signup() {
user := new(models.User)
org := new(models.Organization)
if err := json.Unmarshal(this.Ctx.Input.CopyBody(), &user); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
} else {
if exist, _, err := org.Has(user.Username); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
} else if exist == true {
this.JSONOut(http.StatusBadRequest, "Namespace is occupation already by organization.", nil)
return
}
if exist, _, err := user.Has(user.Username); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
} else if exist == true {
this.JSONOut(http.StatusBadRequest, "User already exist.", nil)
return
} else {
user.Id = string(utils.GeneralKey(user.Username))
user.Created = time.Now().UnixNano() / int64(time.Millisecond)
user.Gravatar = "/static/images/default-user-icon-profile.png"
if err := user.Save(); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
}
memo, _ := json.Marshal(this.Ctx.Input.Header)
user.Log(models.ACTION_SIGNUP, models.LEVELINFORMATIONAL, models.TYPE_WEBV1, user.Id, memo)
this.JSONOut(http.StatusOK, "User singup successfully!", nil)
return
}
}
}
示例14: PutOrg
func (this *OrganizationWebV1Controller) PutOrg() {
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 := org.Has(this.Ctx.Input.Param(":org")); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
} else if exist == false {
this.JSONOut(http.StatusBadRequest, "Organization not exist", nil)
return
}
if err := json.Unmarshal(this.Ctx.Input.CopyBody(), &org); err != nil {
this.JSONOut(http.StatusBadRequest, err.Error(), nil)
return
}
org.Updated = time.Now().UnixNano() / int64(time.Millisecond)
if err := org.Save(); err != nil {
this.JSONOut(http.StatusBadRequest, "Organization save error", nil)
return
}
memo, _ := json.Marshal(this.Ctx.Input.Header)
user.Log(models.ACTION_UPDATE_ORG, models.LEVELINFORMATIONAL, models.TYPE_WEBV1, org.Id, memo)
org.Log(models.ACTION_UPDATE_ORG, models.LEVELINFORMATIONAL, models.TYPE_WEBV1, user.Id, memo)
this.JSONOut(http.StatusOK, "Update organization successfully", nil)
return
}
示例15: GetPing
func (this *PingAPIV2Controller) GetPing() {
if len(this.Ctx.Input.Header("Authorization")) == 0 {
this.JSONOut(http.StatusUnauthorized, "", map[string][]modules.ErrorDescriptor{"errors": []modules.ErrorDescriptor{modules.ErrorDescriptors[modules.APIErrorCodeUnauthorized]}})
return
}
if username, passwd, err := utils.DecodeBasicAuth(this.Ctx.Input.Header("Authorization")); err != nil {
this.JSONOut(http.StatusUnauthorized, "", map[string][]modules.ErrorDescriptor{"errors": []modules.ErrorDescriptor{modules.ErrorDescriptors[modules.APIErrorCodeUnauthorized]}})
return
} else {
user := new(models.User)
if err := user.Get(username, passwd); err != nil {
this.JSONOut(http.StatusUnauthorized, "", map[string][]modules.ErrorDescriptor{"errors": []modules.ErrorDescriptor{modules.ErrorDescriptors[modules.APIErrorCodeUnauthorized]}})
return
}
memo, _ := json.Marshal(this.Ctx.Input.Header)
user.Log(models.ACTION_SIGNUP, models.LEVELINFORMATIONAL, models.TYPE_APIV2, user.Id, memo)
this.JSONOut(http.StatusOK, "", "User authorization successfully.")
return
}
}