переписал получение кейсов, и наметил дальнейшую работу
This commit is contained in:
parent
6de56f3078
commit
7a69ef78be
21
main.go
21
main.go
|
@ -1,10 +1,23 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import "gotest/solutions"
|
import (
|
||||||
|
"fmt"
|
||||||
var URL = "https://kuvaev-ituniversity.vps.elewise.com/tasks/Чудные вхождения в массив"
|
"gotest/solutions"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
func main() {
|
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
|
package solutions
|
||||||
|
|
||||||
type UserName string
|
type Task struct {
|
||||||
|
Payload []int `json:"payload"`
|
||||||
type TaskName string
|
Result []int `json:"result"`
|
||||||
|
|
||||||
type Result int
|
|
||||||
|
|
||||||
type Payload string
|
|
||||||
|
|
||||||
type solutionResult struct {
|
|
||||||
Payload []Payload `json:"payload"`
|
|
||||||
Results []Result `json:"results"`
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type Solution struct {
|
const (
|
||||||
UserName UserName `json:"user_name"`
|
userName string = "il_linberg"
|
||||||
TaskName TaskName `json:"task_name"`
|
Port string = ":1701"
|
||||||
Results solutionResult `json:"results"`
|
SolutionURL string = "kuvaev-ituniversity.vps.elewise.com"
|
||||||
}
|
Rotation string = "Циклическая ротация"
|
||||||
|
FindUnique string = "Чудные вхождения в массив"
|
||||||
|
Cons string = "Проверка последовательности"
|
||||||
|
Missing string = "Поиск отсутствующего элемента"
|
||||||
|
)
|
||||||
|
|
|
@ -1 +1,54 @@
|
||||||
package solutions
|
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
|
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