76 lines
1.7 KiB
Go
76 lines
1.7 KiB
Go
package peppy
|
|
|
|
import (
|
|
"database/sql"
|
|
_json "encoding/json"
|
|
"strconv"
|
|
|
|
"github.com/jmoiron/sqlx"
|
|
"github.com/valyala/fasthttp"
|
|
"github.com/osuyozora/api/common"
|
|
)
|
|
|
|
var modes = []string{"std", "taiko", "ctb", "mania"}
|
|
|
|
var defaultResponse = []struct{}{}
|
|
|
|
func genmode(m string) string {
|
|
i := genmodei(m)
|
|
return modes[i]
|
|
}
|
|
func genmodei(m string) int {
|
|
v := common.Int(m)
|
|
if v > 3 || v < 0 {
|
|
v = 0
|
|
}
|
|
return v
|
|
}
|
|
func rankable(m string) bool {
|
|
x := genmodei(m)
|
|
return x != 2
|
|
}
|
|
|
|
func genUser(c *fasthttp.RequestCtx, db *sqlx.DB) (string, string) {
|
|
var whereClause string
|
|
var p string
|
|
|
|
// used in second case of switch
|
|
s, err := strconv.Atoi(query(c, "u"))
|
|
|
|
switch {
|
|
// We know for sure that it's an username.
|
|
case query(c, "type") == "string":
|
|
whereClause = "users.username_safe = ?"
|
|
p = common.SafeUsername(query(c, "u"))
|
|
// It could be an user ID, so we look for an user with that username first.
|
|
case err == nil:
|
|
err = db.QueryRow("SELECT id FROM users WHERE id = ? LIMIT 1", s).Scan(&p)
|
|
if err == sql.ErrNoRows {
|
|
// If no user with that userID were found, assume username.
|
|
whereClause = "users.username_safe = ?"
|
|
p = common.SafeUsername(query(c, "u"))
|
|
} else {
|
|
// An user with that userID was found. Thus it's an userID.
|
|
whereClause = "users.id = ?"
|
|
}
|
|
// u contains letters, so it's an username.
|
|
default:
|
|
whereClause = "users.username_safe = ?"
|
|
p = common.SafeUsername(query(c, "u"))
|
|
}
|
|
return whereClause, p
|
|
}
|
|
|
|
func query(c *fasthttp.RequestCtx, s string) string {
|
|
return string(c.QueryArgs().Peek(s))
|
|
}
|
|
|
|
func json(c *fasthttp.RequestCtx, code int, data interface{}) {
|
|
c.SetStatusCode(code)
|
|
d, err := _json.Marshal(data)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
c.Write(d)
|
|
}
|