69 lines
1.4 KiB
Go
69 lines
1.4 KiB
Go
package main
|
|
|
|
import (
|
|
"encoding/json"
|
|
"errors"
|
|
"net/http"
|
|
|
|
"github.com/julienschmidt/httprouter"
|
|
)
|
|
|
|
func init() {
|
|
router.GET("/api/auth", apiAuthHandler(validateAuthToken))
|
|
router.POST("/api/auth", apiHandler(checkAuth))
|
|
}
|
|
|
|
func validateAuthToken(s Student, _ httprouter.Params, _ []byte) (interface{}, error) {
|
|
return s, nil
|
|
}
|
|
|
|
type loginForm struct {
|
|
Username string
|
|
Password string
|
|
}
|
|
|
|
func checkAuth(_ httprouter.Params, body []byte) (interface{}, error) {
|
|
var lf loginForm
|
|
if err := json.Unmarshal(body, &lf); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if r, err := http.NewRequest("GET", "https://fic.srs.epita.fr/2020/", nil); err != nil {
|
|
return nil, err
|
|
} else {
|
|
r.SetBasicAuth(lf.Username, lf.Password)
|
|
|
|
if resp, err := http.DefaultClient.Do(r); err != nil {
|
|
return nil, err
|
|
} else {
|
|
defer resp.Body.Close()
|
|
|
|
if resp.StatusCode == http.StatusOK {
|
|
var std Student
|
|
if !studentExists(lf.Username) {
|
|
if std, err = NewStudent(lf.Username); err != nil {
|
|
return nil, err
|
|
}
|
|
} else if std, err = getStudentByLogin(lf.Username); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
session, err := std.NewSession()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
res := map[string]interface{}{}
|
|
res["status"] = "OK"
|
|
res["id_session"] = session.Id
|
|
|
|
return res, nil
|
|
} else {
|
|
return nil, errors.New(`{"status": "Invalid username or password"}`)
|
|
}
|
|
}
|
|
|
|
return nil, nil
|
|
}
|
|
}
|