70 lines
1.3 KiB
Go
70 lines
1.3 KiB
Go
package server
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
"github.com/gin-gonic/gin/binding"
|
|
|
|
"github.com/drone/drone/common"
|
|
)
|
|
|
|
// POST /api/user/tokens
|
|
func PostToken(c *gin.Context) {
|
|
settings := ToSettings(c)
|
|
store := ToDatastore(c)
|
|
sess := ToSession(c)
|
|
user := ToUser(c)
|
|
|
|
// if a session secret is not defined there is no way to
|
|
// generate jwt user tokens, so we must throw an error
|
|
if settings.Session == nil || len(settings.Session.Secret) == 0 {
|
|
c.String(500, "User tokens are not configured")
|
|
return
|
|
}
|
|
|
|
in := &common.Token{}
|
|
if !c.BindWith(in, binding.JSON) {
|
|
return
|
|
}
|
|
|
|
token := &common.Token{}
|
|
token.Label = in.Label
|
|
token.Repos = in.Repos
|
|
token.Scopes = in.Scopes
|
|
token.Login = user.Login
|
|
token.Kind = common.TokenUser
|
|
token.Issued = time.Now().UTC().Unix()
|
|
|
|
err := store.SetToken(token)
|
|
if err != nil {
|
|
c.Fail(400, err)
|
|
}
|
|
|
|
jwt, err := sess.GenerateToken(token)
|
|
if err != nil {
|
|
c.Fail(400, err)
|
|
}
|
|
c.JSON(200, struct {
|
|
*common.Token
|
|
Hash string `json:"hash"`
|
|
}{token, jwt})
|
|
}
|
|
|
|
// DELETE /api/user/tokens/:label
|
|
func DelToken(c *gin.Context) {
|
|
store := ToDatastore(c)
|
|
user := ToUser(c)
|
|
label := c.Params.ByName("label")
|
|
|
|
token, err := store.Token(user.Login, label)
|
|
if err != nil {
|
|
c.Fail(404, err)
|
|
}
|
|
err = store.DelToken(token)
|
|
if err != nil {
|
|
c.Fail(400, err)
|
|
}
|
|
|
|
c.Writer.WriteHeader(200)
|
|
}
|