// Copyright 2021 The casbin 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/casdoor/casdoor/object" ) func (c *ApiController) GetTokens() { owner := c.Input().Get("owner") c.Data["json"] = object.GetTokens(owner) c.ServeJSON() } func (c *ApiController) GetToken() { id := c.Input().Get("id") c.Data["json"] = object.GetToken(id) c.ServeJSON() } func (c *ApiController) UpdateToken() { id := c.Input().Get("id") var token object.Token err := json.Unmarshal(c.Ctx.Input.RequestBody, &token) if err != nil { panic(err) } c.Data["json"] = object.UpdateToken(id, &token) c.ServeJSON() } func (c *ApiController) AddToken() { var token object.Token err := json.Unmarshal(c.Ctx.Input.RequestBody, &token) if err != nil { panic(err) } c.Data["json"] = object.AddToken(&token) c.ServeJSON() } func (c *ApiController) DeleteToken() { var token object.Token err := json.Unmarshal(c.Ctx.Input.RequestBody, &token) if err != nil { panic(err) } c.Data["json"] = object.DeleteToken(&token) c.ServeJSON() } func codeToResponse(code *object.Code) Response { if code.Code == "" { return Response{Status: "error", Msg: code.Message, Data: code.Code} } else { return Response{Status: "ok", Msg: "success", Data: code.Code} } } func (c *ApiController) GetOAuthCode() { userId := c.GetSessionUser() clientId := c.Input().Get("clientId") responseType := c.Input().Get("responseType") redirectUri := c.Input().Get("redirectUri") scope := c.Input().Get("scope") state := c.Input().Get("state") code := object.GetOAuthCode(userId, clientId, responseType, redirectUri, scope, state) c.Data["json"] = codeToResponse(code) c.ServeJSON() } func (c *ApiController) GetOAuthToken() { grantType := c.Input().Get("grant_type") clientId := c.Input().Get("client_id") clientSecret := c.Input().Get("client_secret") code := c.Input().Get("code") c.Data["json"] = object.GetOAuthToken(grantType, clientId, clientSecret, code) c.ServeJSON() }