// Copyright 2021 The Casdoor Authors. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package controllers import ( "encoding/json" "github.com/beego/beego/utils/pagination" "github.com/casdoor/casdoor/object" "github.com/casdoor/casdoor/util" ) // GetOrganizations ... // @Title GetOrganizations // @Tag Organization API // @Description get organizations // @Param owner query string true "owner" // @Success 200 {array} object.Organization The Response object // @router /get-organizations [get] func (c *ApiController) GetOrganizations() { owner := c.Input().Get("owner") limit := c.Input().Get("pageSize") page := c.Input().Get("p") field := c.Input().Get("field") value := c.Input().Get("value") sortField := c.Input().Get("sortField") sortOrder := c.Input().Get("sortOrder") organizationName := c.Input().Get("organizationName") isGlobalAdmin := c.IsGlobalAdmin() if limit == "" || page == "" { var organizations []*object.Organization var err error if isGlobalAdmin { organizations, err = object.GetMaskedOrganizations(object.GetOrganizations(owner)) } else { organizations, err = object.GetMaskedOrganizations(object.GetOrganizations(owner, c.getCurrentUser().Owner)) } if err != nil { c.ResponseError(err.Error()) return } c.ResponseOk(organizations) } else { if !isGlobalAdmin { organizations, err := object.GetMaskedOrganizations(object.GetOrganizations(owner, c.getCurrentUser().Owner)) if err != nil { c.ResponseError(err.Error()) return } c.ResponseOk(organizations) } else { limit := util.ParseInt(limit) count, err := object.GetOrganizationCount(owner, organizationName, field, value) if err != nil { c.ResponseError(err.Error()) return } paginator := pagination.SetPaginator(c.Ctx, limit, count) organizations, err := object.GetMaskedOrganizations(object.GetPaginationOrganizations(owner, organizationName, paginator.Offset(), limit, field, value, sortField, sortOrder)) if err != nil { c.ResponseError(err.Error()) return } c.ResponseOk(organizations, paginator.Nums()) } } } // GetOrganization ... // @Title GetOrganization // @Tag Organization API // @Description get organization // @Param id query string true "organization id" // @Success 200 {object} object.Organization The Response object // @router /get-organization [get] func (c *ApiController) GetOrganization() { id := c.Input().Get("id") organization, err := object.GetMaskedOrganization(object.GetOrganization(id)) if err != nil { c.ResponseError(err.Error()) return } c.ResponseOk(organization) } // UpdateOrganization ... // @Title UpdateOrganization // @Tag Organization API // @Description update organization // @Param id query string true "The id ( owner/name ) of the organization" // @Param body body object.Organization true "The details of the organization" // @Success 200 {object} controllers.Response The Response object // @router /update-organization [post] func (c *ApiController) UpdateOrganization() { id := c.Input().Get("id") var organization object.Organization err := json.Unmarshal(c.Ctx.Input.RequestBody, &organization) if err != nil { c.ResponseError(err.Error()) return } if err = object.CheckIpWhitelist(organization.IpWhitelist, c.GetAcceptLanguage()); err != nil { c.ResponseError(err.Error()) return } isGlobalAdmin, _ := c.isGlobalAdmin() c.Data["json"] = wrapActionResponse(object.UpdateOrganization(id, &organization, isGlobalAdmin)) c.ServeJSON() } // AddOrganization ... // @Title AddOrganization // @Tag Organization API // @Description add organization // @Param body body object.Organization true "The details of the organization" // @Success 200 {object} controllers.Response The Response object // @router /add-organization [post] func (c *ApiController) AddOrganization() { var organization object.Organization err := json.Unmarshal(c.Ctx.Input.RequestBody, &organization) if err != nil { c.ResponseError(err.Error()) return } count, err := object.GetOrganizationCount("", "", "", "") if err != nil { c.ResponseError(err.Error()) return } if err = checkQuotaForOrganization(int(count)); err != nil { c.ResponseError(err.Error()) return } if err = object.CheckIpWhitelist(organization.IpWhitelist, c.GetAcceptLanguage()); err != nil { c.ResponseError(err.Error()) return } c.Data["json"] = wrapActionResponse(object.AddOrganization(&organization)) c.ServeJSON() } // DeleteOrganization ... // @Title DeleteOrganization // @Tag Organization API // @Description delete organization // @Param body body object.Organization true "The details of the organization" // @Success 200 {object} controllers.Response The Response object // @router /delete-organization [post] func (c *ApiController) DeleteOrganization() { var organization object.Organization err := json.Unmarshal(c.Ctx.Input.RequestBody, &organization) if err != nil { c.ResponseError(err.Error()) return } c.Data["json"] = wrapActionResponse(object.DeleteOrganization(&organization)) c.ServeJSON() } // GetDefaultApplication ... // @Title GetDefaultApplication // @Tag Organization API // @Description get default application // @Param id query string true "organization id" // @Success 200 {object} controllers.Response The Response object // @router /get-default-application [get] func (c *ApiController) GetDefaultApplication() { userId := c.GetSessionUsername() id := c.Input().Get("id") application, err := object.GetDefaultApplication(id) if err != nil { c.ResponseError(err.Error()) return } application = object.GetMaskedApplication(application, userId) c.ResponseOk(application) } // GetOrganizationNames ... // @Title GetOrganizationNames // @Tag Organization API // @Param owner query string true "owner" // @Description get all organization name and displayName // @Success 200 {array} object.Organization The Response object // @router /get-organization-names [get] func (c *ApiController) GetOrganizationNames() { owner := c.Input().Get("owner") organizationNames, err := object.GetOrganizationsByFields(owner, []string{"name", "display_name"}...) if err != nil { c.ResponseError(err.Error()) return } c.ResponseOk(organizationNames) }