49 lines
1.0 KiB
Go
49 lines
1.0 KiB
Go
|
package main
|
||
|
|
||
|
import (
|
||
|
"database/sql"
|
||
|
|
||
|
"github.com/gin-gonic/gin"
|
||
|
"github.com/osuYozora/hanayo/routers/oauth"
|
||
|
)
|
||
|
|
||
|
type oauthRequestHandler struct{}
|
||
|
|
||
|
func (o oauthRequestHandler) CheckLoggedInOrRedirect(c *gin.Context) bool {
|
||
|
ctx := getContext(c)
|
||
|
if ctx.User.ID == 0 {
|
||
|
resp403(c)
|
||
|
return false
|
||
|
}
|
||
|
return true
|
||
|
}
|
||
|
|
||
|
func (o oauthRequestHandler) DisplayAuthorizePage(client oauth.Client, c *gin.Context) {
|
||
|
var creatorName string
|
||
|
db.Get(&creatorName, "SELECT username FROM users WHERE id = ? LIMIT 1", client.CreatorID)
|
||
|
|
||
|
c.Header("X-Frame-Options", "deny")
|
||
|
|
||
|
simple(c, getSimpleByFilename("oauth.html"), nil, map[string]interface{}{
|
||
|
"Client": client,
|
||
|
"CreatorName": creatorName,
|
||
|
})
|
||
|
}
|
||
|
|
||
|
func (o oauthRequestHandler) CheckCSRF(c *gin.Context, s string) bool {
|
||
|
b, _ := CSRF.Validate(getContext(c).User.ID, s)
|
||
|
return b
|
||
|
}
|
||
|
|
||
|
func (o oauthRequestHandler) GetDB() *sql.DB {
|
||
|
return db.DB
|
||
|
}
|
||
|
|
||
|
func (o oauthRequestHandler) GetUserID(c *gin.Context) int {
|
||
|
return getContext(c).User.ID
|
||
|
}
|
||
|
|
||
|
func setUpOauth() {
|
||
|
oauth.Initialise(oauthRequestHandler{})
|
||
|
}
|