From 4bdab704a5b2c1b5a7b94307c0dd86b6ee9f6b83 Mon Sep 17 00:00:00 2001 From: ErickSkrauch Date: Fri, 26 Aug 2016 23:45:55 +0300 Subject: [PATCH] =?UTF-8?q?=D0=A3=D0=B4=D0=B0=D0=BB=D0=B5=D0=BD=D0=BE=20?= =?UTF-8?q?=D0=BB=D0=BE=D0=B3=D0=B8=D1=80=D0=BE=D0=B2=D0=B0=D0=BD=D0=B8?= =?UTF-8?q?=D0=B5=20=D0=BE=D0=B6=D0=B8=D0=B4=D0=B0=D0=B5=D0=BC=D0=BE=D0=B9?= =?UTF-8?q?=20=D0=BE=D1=88=D0=B8=D0=B1=D0=BA=D0=B8=20=D1=81=20=D0=BD=D0=B5?= =?UTF-8?q?=D1=81=D1=83=D1=89=D0=B5=D1=81=D1=82=D0=B2=D0=BE=D0=B2=D0=B0?= =?UTF-8?q?=D0=BD=D0=B8=D0=B5=D0=BC=20=D1=81=D0=BA=D0=B8=D0=BD=D0=B0=20?= =?UTF-8?q?=D0=B2=20redis.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lib/data/DataNotFound.go | 11 +++++++++++ lib/data/SkinItem.go | 11 ++++++++--- lib/routes/Cape.go | 2 ++ minecraft-skinsystem.go | 8 ++++++-- 4 files changed, 27 insertions(+), 5 deletions(-) create mode 100644 lib/data/DataNotFound.go diff --git a/lib/data/DataNotFound.go b/lib/data/DataNotFound.go new file mode 100644 index 0000000..0f5e5c2 --- /dev/null +++ b/lib/data/DataNotFound.go @@ -0,0 +1,11 @@ +package data + +import "fmt" + +type DataNotFound struct { + Who string +} + +func (e DataNotFound) Error() string { + return fmt.Sprintf("Skin data not found. Required username \"%v\"", e.Who) +} diff --git a/lib/data/SkinItem.go b/lib/data/SkinItem.go index c381ed5..ee666e1 100644 --- a/lib/data/SkinItem.go +++ b/lib/data/SkinItem.go @@ -6,6 +6,8 @@ import ( "elyby/minecraft-skinsystem/lib/services" "elyby/minecraft-skinsystem/lib/tools" + + "github.com/mediocregopher/radix.v2/redis" ) type SkinItem struct { @@ -25,14 +27,17 @@ func (s *SkinItem) Save() { func FindRecord(username string) (SkinItem, error) { var record SkinItem; - result, err := services.RedisPool.Cmd("GET", tools.BuildKey(username)).Str(); + response := services.RedisPool.Cmd("GET", tools.BuildKey(username)); + if (response.IsType(redis.Nil)) { + return record, DataNotFound{username} + } + + result, err := response.Str() if (err == nil) { decodeErr := json.Unmarshal([]byte(result), &record) if (decodeErr != nil) { log.Println("Cannot decode record data") } - } else { - log.Println("Error on request user data: " + err.Error()) } return record, err diff --git a/lib/routes/Cape.go b/lib/routes/Cape.go index ff58a28..20020b6 100644 --- a/lib/routes/Cape.go +++ b/lib/routes/Cape.go @@ -1,6 +1,7 @@ package routes import ( + "log" "net/http" "github.com/gorilla/mux" @@ -10,6 +11,7 @@ import ( func Cape(w http.ResponseWriter, r *http.Request) { username := tools.ParseUsername(mux.Vars(r)["username"]) + log.Println("request cape for username " + username) http.Redirect(w, r, "http://skins.minecraft.net/MinecraftCloaks/" + username + ".png", 301) } diff --git a/minecraft-skinsystem.go b/minecraft-skinsystem.go index 04c2b0b..49df237 100644 --- a/minecraft-skinsystem.go +++ b/minecraft-skinsystem.go @@ -17,12 +17,16 @@ import ( const redisString string = "redis:6379" func main() { + log.Println("Starting...") + runtime.GOMAXPROCS(runtime.NumCPU()) - pool, redisErr := pool.New("tcp", redisString, 10) + log.Println("Connecting to redis") + redisPool, redisErr := pool.New("tcp", redisString, 10) if redisErr != nil { log.Fatal("Redis unavailable") } + log.Println("Connected to redis") router := mux.NewRouter().StrictSlash(true) router.HandleFunc("/skins/{username}", routes.Skin).Methods("GET").Name("skins") @@ -38,7 +42,7 @@ func main() { apiRouter := router.PathPrefix("/api").Subrouter() apiRouter.HandleFunc("/user/{username}/skin", routes.SetSkin).Methods("POST") - services.RedisPool = pool + services.RedisPool = redisPool services.Router = router /*go func() {