переписал получение кейсов, и наметил дальнейшую работу
This commit is contained in:
parent
6de56f3078
commit
7a69ef78be
21
main.go
21
main.go
|
@ -1,10 +1,23 @@
|
|||
package main
|
||||
|
||||
import "gotest/solutions"
|
||||
|
||||
var URL = "https://kuvaev-ituniversity.vps.elewise.com/tasks/Чудные вхождения в массив"
|
||||
import (
|
||||
"fmt"
|
||||
"gotest/solutions"
|
||||
"net/http"
|
||||
)
|
||||
|
||||
func main() {
|
||||
solutions.NewService().MakeGet(URL)
|
||||
fmt.Println("Live long and prosper")
|
||||
testHandler := func(w http.ResponseWriter, _ *http.Request) {
|
||||
b, _ := solutions.ProcessTask(solutions.Rotation) //воткнул что бы не ругался на не использование
|
||||
//io.WriteString(w, string(b))
|
||||
fmt.Println(b)
|
||||
}
|
||||
|
||||
http.HandleFunc("/status", testHandler)
|
||||
|
||||
err := http.ListenAndServe(solutions.Port, nil)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,41 +0,0 @@
|
|||
package solutions
|
||||
|
||||
import (
|
||||
"io"
|
||||
"log"
|
||||
"net/http"
|
||||
)
|
||||
|
||||
func NewService() taskService {
|
||||
return taskService{}
|
||||
}
|
||||
|
||||
type taskService struct {
|
||||
store solutionResult
|
||||
}
|
||||
|
||||
func (t taskService) MakeGet(url string) {
|
||||
res, err := http.Get(url)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
body, err := io.ReadAll(res.Body)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
res.Body.Close()
|
||||
|
||||
//b, _ := asn1.MarshalWithParams()
|
||||
//t.store.Add(Payload(b))
|
||||
//
|
||||
//fmt.Println(b)
|
||||
}
|
||||
|
||||
//func FindUnique() {
|
||||
// fmt.Println()
|
||||
//
|
||||
// //for i, _ := range c {
|
||||
// // fmt.Println(i)
|
||||
// //}
|
||||
//
|
||||
//}
|
|
@ -1,20 +1,16 @@
|
|||
package solutions
|
||||
|
||||
type UserName string
|
||||
|
||||
type TaskName string
|
||||
|
||||
type Result int
|
||||
|
||||
type Payload string
|
||||
|
||||
type solutionResult struct {
|
||||
Payload []Payload `json:"payload"`
|
||||
Results []Result `json:"results"`
|
||||
type Task struct {
|
||||
Payload []int `json:"payload"`
|
||||
Result []int `json:"result"`
|
||||
}
|
||||
|
||||
type Solution struct {
|
||||
UserName UserName `json:"user_name"`
|
||||
TaskName TaskName `json:"task_name"`
|
||||
Results solutionResult `json:"results"`
|
||||
}
|
||||
const (
|
||||
userName string = "il_linberg"
|
||||
Port string = ":1701"
|
||||
SolutionURL string = "kuvaev-ituniversity.vps.elewise.com"
|
||||
Rotation string = "Циклическая ротация"
|
||||
FindUnique string = "Чудные вхождения в массив"
|
||||
Cons string = "Проверка последовательности"
|
||||
Missing string = "Поиск отсутствующего элемента"
|
||||
)
|
||||
|
|
|
@ -1 +1,54 @@
|
|||
package solutions
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"io"
|
||||
"log"
|
||||
"net/http"
|
||||
)
|
||||
|
||||
func ProcessTask(taskName string) ([]byte, error) {
|
||||
//получаем условия для задач
|
||||
var taskCases []json.RawMessage
|
||||
err := getCases(taskName, taskCases)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
return []byte{}, err
|
||||
}
|
||||
//решение задач
|
||||
//
|
||||
|
||||
//сборка результата
|
||||
//
|
||||
|
||||
//должен вернуть вывод решения
|
||||
return nil, nil
|
||||
}
|
||||
|
||||
func getCases(taskName string, taskCases []json.RawMessage) error {
|
||||
|
||||
response, err := http.Get("http://" + SolutionURL + "/tasks/" + taskName)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
return err
|
||||
}
|
||||
defer func(Body io.ReadCloser) {
|
||||
err := Body.Close()
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
}(response.Body)
|
||||
|
||||
payload, err := io.ReadAll(response.Body)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
return err
|
||||
}
|
||||
|
||||
err = json.Unmarshal(payload, &taskCases)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
|
|
@ -1,9 +1 @@
|
|||
package solutions
|
||||
|
||||
func NewPayloadStore() solutionResult {
|
||||
return solutionResult{Payload: []Payload{}}
|
||||
}
|
||||
|
||||
func (c *solutionResult) Add(payload Payload) {
|
||||
c.Payload = append(c.Payload, payload)
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue