Add API for keys and files

This commit is contained in:
nemunaire 2016-01-18 19:41:04 +01:00
parent 381aefa597
commit 8655997246
3 changed files with 153 additions and 53 deletions

93
admin/api_exercice.go Normal file
View file

@ -0,0 +1,93 @@
package main
import (
"encoding/json"
"errors"
"strconv"
"srs.epita.fr/fic-server/libfic"
)
type uploadedExercice struct {
Title string
Statement string
Hint string
Depend *int
Gain int
VideoURI string
}
func createExercice(theme fic.Theme, args []string, body []byte) (interface{}, error) {
if len(args) >= 1 {
if eid, err := strconv.Atoi(string(args[0])); err != nil {
return nil, err
} else if exercice, err := theme.GetExercice(eid); err != nil {
return nil, err
} else {
if args[1] == "files" {
return createExerciceFile(theme, exercice, args[2:], body)
} else if args[1] == "keys" {
return createExerciceKey(theme, exercice, args[2:], body)
}
}
return nil, nil
} else {
// Create a new exercice
var ue uploadedExercice
if err := json.Unmarshal(body, &ue); err != nil {
return nil, err
}
if len(ue.Title) == 0 {
return nil, errors.New("Title not filled")
}
var depend *fic.Exercice = nil
if ue.Depend != nil {
if d, err := fic.GetExercice(*ue.Depend); err != nil {
return nil, err
} else {
depend = &d
}
}
return theme.AddExercice(ue.Title, ue.Statement, ue.Hint, depend, ue.Gain, ue.VideoURI)
}
}
type uploadedFile struct {
URI string
}
func createExerciceFile(theme fic.Theme, exercice fic.Exercice, args []string, body []byte) (interface{}, error) {
var uf uploadedFile
if err := json.Unmarshal(body, &uf); err != nil {
return nil, err
}
if len(uf.URI) == 0 {
return nil, errors.New("URI not filled")
}
// TODO: se connecter à OwnCloud
return nil, nil
}
type uploadedKey struct {
Name string
Key string
}
func createExerciceKey(theme fic.Theme, exercice fic.Exercice, args []string, body []byte) (interface{}, error) {
var uk uploadedKey
if err := json.Unmarshal(body, &uk); err != nil {
return nil, err
}
if len(uk.Key) == 0 {
return nil, errors.New("Key not filled")
}
return exercice.AddRawKey(uk.Name, uk.Key)
}

View file

@ -4,6 +4,7 @@ import (
"encoding/json" "encoding/json"
"fmt" "fmt"
"strconv" "strconv"
"time"
"srs.epita.fr/fic-server/libfic" "srs.epita.fr/fic-server/libfic"
) )
@ -15,41 +16,55 @@ var ApiTeamsRouting = map[string]DispatchFunction{
"DELETE": deletionTeam, "DELETE": deletionTeam,
} }
type uploadedTeam struct { type myTeamFile struct {
Name string Path string `json:"path"`
Name string `json:"name"`
Checksum []byte `json:"checksum"`
Size int64 `json:"size"`
} }
type myTeamExercice struct {
type uploadedMember struct { Statement string `json:"statement"`
Firstname string Hint string `json:"hint"`
Lastname string Gain int64 `json:"gain"`
Nickname string Files []myTeamFile `json:"files"`
Company string Solved bool `json:"solved"`
SolvedTime time.Time `json:"solved_time"`
SolvedNumber int64 `json:"solved_number"`
}
type myTeam struct {
Id int64 `json:"team_id"`
Exercices map[string]myTeamExercice `json:"exercices"`
} }
func myJSONTeam(t fic.Team) (interface{}, error) { func myJSONTeam(t fic.Team) (interface{}, error) {
ret := map[string]interface{}{} ret := myTeam{}
ret.Id = t.Id
ret["team_id"] = t.Id ret.Exercices = map[string]myTeamExercice{}
exercices := map[string]interface{}{}
if exos, err := fic.GetExercices(); err != nil { if exos, err := fic.GetExercices(); err != nil {
return ret, err return ret, err
} else { } else {
for _, e := range exos { for _, e := range exos {
if t.HasAccess(e) { if t.HasAccess(e) {
exercice := map[string]interface{}{} exercice := myTeamExercice{}
exercice["statement"] = e.Statement exercice.Statement = e.Statement
exercice["hint"] = e.Hint exercice.Hint = e.Hint
exercice["solved"] = t.HasSolved(e) exercice.Solved, exercice.SolvedTime, exercice.SolvedNumber = t.HasSolved(e)
exercice.Files = []myTeamFile{}
exercices[fmt.Sprintf("%d", e.Id)] = exercice if files, err := e.GetFiles(); err != nil {
return nil, err
} else {
for _, f := range files {
exercice.Files = append(exercice.Files, myTeamFile{f.Path, f.Name, f.Checksum, f.Size})
}
}
ret.Exercices[fmt.Sprintf("%d", e.Id)] = exercice
} }
} }
} }
ret["exercices"] = exercices
return ret, nil return ret, nil
} }
@ -66,6 +81,17 @@ func nginxGenTeam() (string, error) {
} }
} }
type uploadedTeam struct {
Name string
}
type uploadedMember struct {
Firstname string
Lastname string
Nickname string
Company string
}
func listTeam(args []string, body []byte) (interface{}, error) { func listTeam(args []string, body []byte) (interface{}, error) {
if len(args) == 2 { if len(args) == 2 {
if tid, err := strconv.Atoi(string(args[0])); err != nil { if tid, err := strconv.Atoi(string(args[0])); err != nil {

View file

@ -18,15 +18,6 @@ type uploadedTheme struct {
Name string Name string
} }
type uploadedExercice struct {
Title string
Statement string
Hint string
Depend *int
Gain int
VideoURI string
}
func getTheme(args []string) (fic.Theme, error) { func getTheme(args []string) (fic.Theme, error) {
if tid, err := strconv.Atoi(string(args[0])); err != nil { if tid, err := strconv.Atoi(string(args[0])); err != nil {
return fic.Theme{}, err return fic.Theme{}, err
@ -46,43 +37,33 @@ func getExercice(args []string) (fic.Exercice, error) {
} }
func listTheme(args []string, body []byte) (interface{}, error) { func listTheme(args []string, body []byte) (interface{}, error) {
if len(args) == 2 { if len(args) == 3 {
if e, err := getExercice(args); err != nil {
return nil, err
} else {
if args[2] == "files" {
return e.GetFiles()
} else if args[2] == "keys" {
return e.GetKeys()
}
}
} else if len(args) == 2 {
return getExercice(args) return getExercice(args)
} else if len(args) == 1 { } else if len(args) == 1 {
return getTheme(args) return getTheme(args)
} else if len(args) == 0 { } else if len(args) == 0 {
// List all themes // List all themes
return fic.GetThemes() return fic.GetThemes()
} else {
return nil, nil
} }
return nil, nil
} }
func creationTheme(args []string, body []byte) (interface{}, error) { func creationTheme(args []string, body []byte) (interface{}, error) {
if len(args) == 1 { if len(args) >= 1 {
if theme, err := getTheme(args); err != nil { if theme, err := getTheme(args); err != nil {
return nil, err return nil, err
} else { } else {
// Create a new exercice return createExercice(theme, args[1:], body)
var ue uploadedExercice
if err := json.Unmarshal(body, &ue); err != nil {
return nil, err
}
if len(ue.Title) == 0 {
return nil, errors.New("Title not filled")
}
var depend *fic.Exercice = nil
if ue.Depend != nil {
if d, err := fic.GetExercice(*ue.Depend); err != nil {
return nil, err
} else {
depend = &d
}
}
return theme.AddExercice(ue.Title, ue.Statement, ue.Hint, depend, ue.Gain, ue.VideoURI)
} }
} else if len(args) == 0 { } else if len(args) == 0 {
// Create a new theme // Create a new theme