From ef7a22dcae0b6cda8fbc511305570dad9ec9e632 Mon Sep 17 00:00:00 2001 From: minoic Date: Wed, 9 Feb 2022 16:50:00 +0800 Subject: [PATCH 1/6] update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index f7c688e..10a96cc 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,7 @@ 当前适配翼龙面板 v1.7.0 -[Docker镜像]([minoic/peo - Docker Image | Docker Hub](https://hub.docker.com/r/minoic/peo)) +[minoic/peo - Docker Image | Docker Hub](https://hub.docker.com/r/minoic/peo) #### 特性 From c54d5307a9644060ac9d66692eb1d813a7c11d3c Mon Sep 17 00:00:00 2001 From: minoic Date: Fri, 11 Feb 2022 17:00:25 +0800 Subject: [PATCH 2/6] fix fixture mail settings in code --- conf/settings.conf | 1 + docker/conf/settings.conf | 1 + internal/email/mail_generate.go | 8 ++++---- 3 files changed, 6 insertions(+), 4 deletions(-) diff --git a/conf/settings.conf b/conf/settings.conf index 2f32e00..2cd37e7 100644 --- a/conf/settings.conf +++ b/conf/settings.conf @@ -51,6 +51,7 @@ SMTPPort = 80 SMTPSendFrom = "ADMIN " SMTPUsername = "admin@example.com" SMTPUserPassword = "yourpassword" +SMTPLogo = "" #TLS/SSL SMTPEncryption = "TLS" #if DeleteEmailConfirm be set to true all admins will receive an email before Server being deleted diff --git a/docker/conf/settings.conf b/docker/conf/settings.conf index 88376f5..fb03570 100644 --- a/docker/conf/settings.conf +++ b/docker/conf/settings.conf @@ -51,6 +51,7 @@ SMTPPort = 80 SMTPSendFrom = "ADMIN " SMTPUsername = "admin@example.com" SMTPUserPassword = "yourpassword" +SMTPLogo = "" #TLS/SSL SMTPEncryption = "TLS" #if DeleteEmailConfirm be set to true all admins will receive an email before Server being deleted diff --git a/internal/email/mail_generate.go b/internal/email/mail_generate.go index c6c1520..29b763c 100644 --- a/internal/email/mail_generate.go +++ b/internal/email/mail_generate.go @@ -12,8 +12,8 @@ func getProd() hermes.Hermes { Product: hermes.Product{ Name: configure.WebApplicationName + " Mail", Link: configure.WebHostName, - Logo: "", - Copyright: "Copyright © 2020 Mino. All rights reserved.", + Logo: configure.GetConf().String("SMTPLogo"), + Copyright: "Copyright 2021 MinoIC. All rights reserved.", TroubleText: "如果点击链接无效,请复制下列链接并在浏览器中打开:", }, } @@ -38,7 +38,7 @@ func genRegConfirmMail(userName string, key string) (string, string) { }, }, Outros: []string{ - "需要帮助请发邮件至 cytusd@outlook.com", + "需要帮助请在网站内发送工单", }, }} mailBody, err := h.GenerateHTML(email) @@ -62,7 +62,7 @@ func genForgetPasswordEmail(key string) (string, string) { "您正在修改密码,验证码为:" + key, }, Outros: []string{ - "需要帮助请发邮件至 cytusd@outlook.com", + "需要帮助请在网站内发送工单", }, }} mailBody, err := h.GenerateHTML(email) From 1a7daf27d5c2061be24b1085bd41cfd6d1c66658 Mon Sep 17 00:00:00 2001 From: minoic <55825043+minoic@users.noreply.github.com> Date: Thu, 3 Mar 2022 09:35:18 +0800 Subject: [PATCH 3/6] Create LICENSE --- LICENSE | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 LICENSE diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..4373f37 --- /dev/null +++ b/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2022 minoic + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. From c97edea83d1a2cb608b5975f05aff321a30af7a3 Mon Sep 17 00:00:00 2001 From: minoic Date: Wed, 18 May 2022 19:34:26 +0800 Subject: [PATCH 4/6] fix endless waiting for mc ping --- conf/app.conf | 4 +- conf/settings.conf | 2 +- .../controllers/admin_console_controller.go | 5 +- .../controllers/forget_password_controller.go | 5 +- internal/controllers/login_controller.go | 5 +- internal/controllers/new_ware_controller.go | 5 +- internal/controllers/order_info_controller.go | 5 +- internal/controllers/reg_controller.go | 5 +- .../controllers/user_console_controller.go | 3 +- .../controllers/user_recharge_controller.go | 5 +- .../controllers/user_settings_controller.go | 5 +- .../controllers/user_work_order_controller.go | 5 +- internal/status/minecraft.go | 68 ++++++++++++------- 13 files changed, 85 insertions(+), 37 deletions(-) diff --git a/conf/app.conf b/conf/app.conf index 8e0de24..73eabd2 100644 --- a/conf/app.conf +++ b/conf/app.conf @@ -9,8 +9,8 @@ sessionproviderconfig = "127.0.0.1:6379" # NOT RECOMMENDED TO EDIT appname = peo -httpaddr = "localhost" -httpport = 5701 +httpaddr = "0.0.0.0" +httpport = 8080 runmode = "dev" enablexsrf = true xsrfkey = 61oETzKXQAGaYdkL5gEmGeJJFuYh7EQnp2XdTP1o diff --git a/conf/settings.conf b/conf/settings.conf index 2cd37e7..ae52fde 100644 --- a/conf/settings.conf +++ b/conf/settings.conf @@ -72,7 +72,7 @@ CacheFileDirectoryLevel = "2" CacheFileEmbedExpiry = "120" #CacheMode = "redis" CacheRedisKey = "collectionName" -CacheRedisCONN = ":6039" +CacheRedisCONN = ":6379" CacheRedisdbNum = "0" CacheRedisPassword = "" #CacheMode = "memcache" diff --git a/internal/controllers/admin_console_controller.go b/internal/controllers/admin_console_controller.go index 573cced..bd0a14b 100644 --- a/internal/controllers/admin_console_controller.go +++ b/internal/controllers/admin_console_controller.go @@ -443,7 +443,10 @@ func (this *AdminConsoleController) CheckXSRFCookie() bool { if !this.EnableXSRF { return true } - token := this.Ctx.Input.Query("_xsrf") + token := this.GetString("_xsrf") + if token == "" { + token = this.Ctx.Input.Query("_xsrf") + } if token == "" { token = this.Ctx.Request.Header.Get("X-Xsrftoken") } diff --git a/internal/controllers/forget_password_controller.go b/internal/controllers/forget_password_controller.go index 99c7521..cf638a8 100644 --- a/internal/controllers/forget_password_controller.go +++ b/internal/controllers/forget_password_controller.go @@ -88,7 +88,10 @@ func (this *ForgetPasswordController) CheckXSRFCookie() bool { if !this.EnableXSRF { return true } - token := this.Ctx.Input.Query("_xsrf") + token := this.GetString("_xsrf") + if token == "" { + token = this.Ctx.Input.Query("_xsrf") + } if token == "" { token = this.Ctx.Request.Header.Get("X-Xsrftoken") } diff --git a/internal/controllers/login_controller.go b/internal/controllers/login_controller.go index 2ee07f2..999b0d5 100644 --- a/internal/controllers/login_controller.go +++ b/internal/controllers/login_controller.go @@ -61,7 +61,10 @@ func (this *LoginController) CheckXSRFCookie() bool { if !this.EnableXSRF { return true } - token := this.Ctx.Input.Query("_xsrf") + token := this.GetString("_xsrf") + if token == "" { + token = this.Ctx.Input.Query("_xsrf") + } if token == "" { token = this.Ctx.Request.Header.Get("X-Xsrftoken") } diff --git a/internal/controllers/new_ware_controller.go b/internal/controllers/new_ware_controller.go index e4219c5..9217d14 100644 --- a/internal/controllers/new_ware_controller.go +++ b/internal/controllers/new_ware_controller.go @@ -377,7 +377,10 @@ func (this *NewWareController) CheckXSRFCookie() bool { if !this.EnableXSRF { return true } - token := this.Ctx.Input.Query("_xsrf") + token := this.GetString("_xsrf") + if token == "" { + token = this.Ctx.Input.Query("_xsrf") + } if token == "" { token = this.Ctx.Request.Header.Get("X-Xsrftoken") } diff --git a/internal/controllers/order_info_controller.go b/internal/controllers/order_info_controller.go index 52519a5..6205a10 100644 --- a/internal/controllers/order_info_controller.go +++ b/internal/controllers/order_info_controller.go @@ -178,7 +178,10 @@ func (this *OrderInfoController) CheckXSRFCookie() bool { if !this.EnableXSRF { return true } - token := this.Ctx.Input.Query("_xsrf") + token := this.GetString("_xsrf") + if token == "" { + token = this.Ctx.Input.Query("_xsrf") + } if token == "" { token = this.Ctx.Request.Header.Get("X-Xsrftoken") } diff --git a/internal/controllers/reg_controller.go b/internal/controllers/reg_controller.go index 3ca1ed6..562ea7f 100644 --- a/internal/controllers/reg_controller.go +++ b/internal/controllers/reg_controller.go @@ -218,7 +218,10 @@ func (this *RegController) CheckXSRFCookie() bool { if !this.EnableXSRF { return true } - token := this.Ctx.Input.Query("_xsrf") + token := this.GetString("_xsrf") + if token == "" { + token = this.Ctx.Input.Query("_xsrf") + } if token == "" { token = this.Ctx.Request.Header.Get("X-Xsrftoken") } diff --git a/internal/controllers/user_console_controller.go b/internal/controllers/user_console_controller.go index c2cc5b5..e72b45a 100644 --- a/internal/controllers/user_console_controller.go +++ b/internal/controllers/user_console_controller.go @@ -77,12 +77,13 @@ func RefreshServerInfo() { ) DB.Find(&entities) pongsSync.pongs = make([]status.Pong, len(entities)) - wg.Add(len(entities)) for i, e := range entities { + wg.Add(1) go func(host string, index int) { defer wg.Done() pongTemp, err := status.Ping(host) if err != nil { + glgf.Error("mc ping", host, err) pongsSync.pongs[index] = status.Pong{} } else { pongsSync.pongs[index] = *pongTemp diff --git a/internal/controllers/user_recharge_controller.go b/internal/controllers/user_recharge_controller.go index 1a35646..e63c6d8 100644 --- a/internal/controllers/user_recharge_controller.go +++ b/internal/controllers/user_recharge_controller.go @@ -187,7 +187,10 @@ func (this *UserRechargeController) CheckXSRFCookie() bool { if !this.EnableXSRF { return true } - token := this.Ctx.Input.Query("_xsrf") + token := this.GetString("_xsrf") + if token == "" { + token = this.Ctx.Input.Query("_xsrf") + } if token == "" { token = this.Ctx.Request.Header.Get("X-Xsrftoken") } diff --git a/internal/controllers/user_settings_controller.go b/internal/controllers/user_settings_controller.go index 541cf4e..e2438d2 100644 --- a/internal/controllers/user_settings_controller.go +++ b/internal/controllers/user_settings_controller.go @@ -202,7 +202,10 @@ func (this *UserSettingsController) CheckXSRFCookie() bool { if !this.EnableXSRF { return true } - token := this.Ctx.Input.Query("_xsrf") + token := this.GetString("_xsrf") + if token == "" { + token = this.Ctx.Input.Query("_xsrf") + } if token == "" { token = this.Ctx.Request.Header.Get("X-Xsrftoken") } diff --git a/internal/controllers/user_work_order_controller.go b/internal/controllers/user_work_order_controller.go index 0a05ff6..35d7fd0 100644 --- a/internal/controllers/user_work_order_controller.go +++ b/internal/controllers/user_work_order_controller.go @@ -83,7 +83,10 @@ func (this *UserWorkOrderController) CheckXSRFCookie() bool { if !this.EnableXSRF { return true } - token := this.Ctx.Input.Query("_xsrf") + token := this.GetString("_xsrf") + if token == "" { + token = this.Ctx.Input.Query("_xsrf") + } if token == "" { token = this.Ctx.Request.Header.Get("X-Xsrftoken") } diff --git a/internal/status/minecraft.go b/internal/status/minecraft.go index b728411..17168e5 100644 --- a/internal/status/minecraft.go +++ b/internal/status/minecraft.go @@ -3,12 +3,14 @@ package status import ( "bufio" "bytes" + "context" "encoding/binary" "encoding/json" "errors" "io" "net" "strconv" + "time" ) const ( @@ -44,32 +46,50 @@ type Pong struct { } func Ping(host string) (*Pong, error) { - conn, err := net.Dial("tcp", host) - if err != nil { - return nil, err - } - defer conn.Close() - if err := sendHandshake(conn, host); err != nil { - return nil, err - } - if err := sendStatusRequest(conn); err != nil { + ctx, cancel := context.WithTimeout(context.Background(), 2*time.Second) + retc := make(chan *Pong) + errc := make(chan error) + go func(ctx context.Context) { + defer cancel() + conn, err := net.Dial("tcp", host) + if err != nil { + errc <- err + return + } + defer conn.Close() + if err := sendHandshake(conn, host); err != nil { + errc <- err + return + } + if err := sendStatusRequest(conn); err != nil { + errc <- err + return + } + p, err := readPong(conn) + // glg.Debug(Pong.FavIcon) + if err != nil { + // glg.Error(err) + errc <- err + return + } + if p.FavIcon == "" { + p.FavIcon = "" + } + if p.Description.Text != "" { + p.Description.Des = p.Description.Text + } else { + p.Description.Des = p.Description.Translate + } + retc <- p + }(ctx) + select { + case ret := <-retc: + return ret, nil + case err := <-errc: return nil, err + case <-ctx.Done(): + return nil, errors.New("time exceeded") } - p, err := readPong(conn) - // glg.Debug(Pong.FavIcon) - if err != nil { - // glg.Error(err) - return nil, err - } - if p.FavIcon == "" { - p.FavIcon = "" - } - if p.Description.Text != "" { - p.Description.Des = p.Description.Text - } else { - p.Description.Des = p.Description.Translate - } - return p, nil } func makePacket(pl *bytes.Buffer) *bytes.Buffer { From 1ca672e70d8541c3a6a8d5aa3985f3094ca2f7a2 Mon Sep 17 00:00:00 2001 From: minoic Date: Wed, 18 May 2022 21:24:45 +0800 Subject: [PATCH 5/6] fix creating pterodactyl server panic --- internal/pterodactyl/api_manager.go | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/internal/pterodactyl/api_manager.go b/internal/pterodactyl/api_manager.go index 5136372..6b942e6 100644 --- a/internal/pterodactyl/api_manager.go +++ b/internal/pterodactyl/api_manager.go @@ -2,9 +2,9 @@ package pterodactyl import ( "bytes" + "encoding/json" "errors" "fmt" - jsoniter "github.com/json-iterator/go" "io/ioutil" "net/http" "strconv" @@ -25,8 +25,6 @@ func NewClient(url string, token string) *Client { return &Client{url: url, token: token} } -var json = jsoniter.ConfigCompatibleWithStandardLibrary - func (this *Client) HostName() string { return this.url } From 4e239ba5f837f074573d95e3616d8ef97b0f0bde Mon Sep 17 00:00:00 2001 From: minoic Date: Thu, 19 May 2022 11:16:05 +0800 Subject: [PATCH 6/6] feature toggle album feature display egg description --- Dockerfile | 16 ++++ cmd/main.go | 2 +- conf/app.conf | 4 +- conf/settings.conf | 18 ++-- .../docker-compose.yml => docker-compose.yml | 0 docker/conf/app.conf | 20 ---- docker/conf/settings.conf | 94 ------------------- internal/controllers/menu_controller.go | 1 + views/UserSettings.html | 2 + views/tpls/navbar.html | 2 + views/tpls/serverinfoModal.html | 9 +- 11 files changed, 39 insertions(+), 129 deletions(-) create mode 100644 Dockerfile rename docker/docker-compose.yml => docker-compose.yml (100%) delete mode 100644 docker/conf/app.conf delete mode 100644 docker/conf/settings.conf diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..158e1cc --- /dev/null +++ b/Dockerfile @@ -0,0 +1,16 @@ +FROM alpine + +VOLUME ["/log","/conf"] +RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.tuna.tsinghua.edu.cn/g' /etc/apk/repositories \ + && apk add tzdata \ + && apk add ca-certificates \ + && update-ca-certificates +ENV TZ=Asia/Shanghai +COPY conf . +COPY static . +COPY log . +COPY views . +COPY build/peo_linux_amd64_linux . +EXPOSE 8080 + +ENTRYPOINT ["/peo_linux_amd64_linux"] \ No newline at end of file diff --git a/cmd/main.go b/cmd/main.go index 5812afd..67e4abb 100644 --- a/cmd/main.go +++ b/cmd/main.go @@ -6,7 +6,7 @@ import ( "github.com/minoic/peo/internal/cron" ) -const Version = "v0.1.8" +const Version = "v0.1.9" func main() { api.InitRouter() diff --git a/conf/app.conf b/conf/app.conf index 73eabd2..55cffc8 100644 --- a/conf/app.conf +++ b/conf/app.conf @@ -4,13 +4,11 @@ #postgresql "postgres://pqgotest:password@localhost/pqgotest?sslmode=verify-full" #couchbase "http://bucketname:bucketpass@myserver:8091" sessionprovider = "redis" -sessionproviderconfig = "127.0.0.1:6379" +sessionproviderconfig = "redis:6379" # NOT RECOMMENDED TO EDIT appname = peo -httpaddr = "0.0.0.0" -httpport = 8080 runmode = "dev" enablexsrf = true xsrfkey = 61oETzKXQAGaYdkL5gEmGeJJFuYh7EQnp2XdTP1o diff --git a/conf/settings.conf b/conf/settings.conf index ae52fde..b419159 100644 --- a/conf/settings.conf +++ b/conf/settings.conf @@ -32,14 +32,14 @@ Serverpassword = "" # Choose database to use: MYSQL Database = "MYSQL" # salt -DatabaseSalt = "salt_salt" +DatabaseSalt = "PEOSALT" UseGormCache = true -SqlTablePrefix = "pe_" +SqlTablePrefix = "peo_" #Fill the account info if database = "MYSQL" -MYSQLHost = "localhost:3306" +MYSQLHost = "mysql:3306" MYSQLUsername = "root" -MYSQLUserPassword = "" -MYSQLDatabaseName = "" +MYSQLUserPassword = "PEOMYSQLPASSWORD" +MYSQLDatabaseName = "peo" ############################ #SMTP settings @@ -62,7 +62,7 @@ DeleteEmailConfirm = true ############################ #change your cache settings #CacheMode = "memory"/"file"/"redis"/"memcache" -CacheMode = "memory" +CacheMode = "redis" #CacheMode = "memory" CacheMemoryGCInterval = 60 #CacheMode = "file" @@ -72,7 +72,7 @@ CacheFileDirectoryLevel = "2" CacheFileEmbedExpiry = "120" #CacheMode = "redis" CacheRedisKey = "collectionName" -CacheRedisCONN = ":6379" +CacheRedisCONN = "redis:6379" CacheRedisdbNum = "0" CacheRedisPassword = "" #CacheMode = "memcache" @@ -91,4 +91,6 @@ AutoTaskInterval = 10 AliPayEnabled = false AliPayPublicKey = "" AliPayPrivateKey = "" -AliPayAppID = "" \ No newline at end of file +AliPayAppID = "" +# toggle album +AlbumEnabled = false \ No newline at end of file diff --git a/docker/docker-compose.yml b/docker-compose.yml similarity index 100% rename from docker/docker-compose.yml rename to docker-compose.yml diff --git a/docker/conf/app.conf b/docker/conf/app.conf deleted file mode 100644 index 55cffc8..0000000 --- a/docker/conf/app.conf +++ /dev/null @@ -1,20 +0,0 @@ -#sessionprovider Examples -#redis "127.0.0.1:6379" -#memcache "127.0.0.1:7080" -#postgresql "postgres://pqgotest:password@localhost/pqgotest?sslmode=verify-full" -#couchbase "http://bucketname:bucketpass@myserver:8091" -sessionprovider = "redis" -sessionproviderconfig = "redis:6379" - - -# NOT RECOMMENDED TO EDIT -appname = peo -runmode = "dev" -enablexsrf = true -xsrfkey = 61oETzKXQAGaYdkL5gEmGeJJFuYh7EQnp2XdTP1o -xsrfexpire = 3600 -sessionon = true -sessionname = "tOZENDENoNOS" -sessiongcmaxlifetime = 315360000 -sessioncookielifetime = 315360000 -copyrequestbody = true diff --git a/docker/conf/settings.conf b/docker/conf/settings.conf deleted file mode 100644 index fb03570..0000000 --- a/docker/conf/settings.conf +++ /dev/null @@ -1,94 +0,0 @@ -############################ -#Please rename this file to settings.config after edited it -############################ - -############################ -#Basic Settings -############################ -# hostname to visit your web site -WebHostName = "example.com" - # use SSL or not -WebSecure = false -# website name to show -WebApplicationName = "MinoIC - PE" - # website description to show -WebDescription = "Pterodactyl 服务器出售系统" -# website Admin address -WebAdminAddress = "ADMIN " - -############################ -#Pterodactyl Settings -############################ -# your pterodactyl panel hostname -Serverhostname = "pterodactyl.example.com" -# wether your pterodactyl use SSL or not -Serversecure = false -# pterodactyl admin token -Serverpassword = "" - -############################ -#Database Settings -############################ -# Choose database to use: MYSQL -Database = "MYSQL" -# salt -DatabaseSalt = "PEOSALT" -UseGormCache = true -SqlTablePrefix = "peo_" -#Fill the account info if database = "MYSQL" -MYSQLHost = "mysql:3306" -MYSQLUsername = "root" -MYSQLUserPassword = "PEOMYSQLPASSWORD" -MYSQLDatabaseName = "peo" - -############################ -#SMTP settings -############################ -# if set to false, we wont send any email to user -SMTPEnabled = false -SMTPHost = "smtpdm-ap-southeast-1.aliyun.com" -SMTPPort = 80 -SMTPSendFrom = "ADMIN " -SMTPUsername = "admin@example.com" -SMTPUserPassword = "yourpassword" -SMTPLogo = "" - #TLS/SSL -SMTPEncryption = "TLS" -#if DeleteEmailConfirm be set to true all admins will receive an email before Server being deleted -DeleteEmailConfirm = true - -############################ -#Cache Settings -############################ -#change your cache settings -#CacheMode = "memory"/"file"/"redis"/"memcache" -CacheMode = "redis" -#CacheMode = "memory" -CacheMemoryGCInterval = 60 -#CacheMode = "file" -CacheFilePath = "./cache" -CacheFileSuffix = ".cache" -CacheFileDirectoryLevel = "2" -CacheFileEmbedExpiry = "120" -#CacheMode = "redis" -CacheRedisKey = "collectionName" -CacheRedisCONN = "redis:6379" -CacheRedisdbNum = "0" -CacheRedisPassword = "" -#CacheMode = "memcache" -CacheMemcacheCONN = "127.0.0.1:11211" - -############################ -#Misc Settings -############################ -# check if you want user to recharge balance -RechargeMode = false -# if set to false, we wont accept any discount -TotalDiscount = false -# Task run interval in seconds, 10 is recommended -AutoTaskInterval = 10 -# fill if you want to enable alipay recharge -AliPayEnabled = false -AliPayPublicKey = "" -AliPayPrivateKey = "" -AliPayAppID = "" \ No newline at end of file diff --git a/internal/controllers/menu_controller.go b/internal/controllers/menu_controller.go index ed1e115..664e1ac 100644 --- a/internal/controllers/menu_controller.go +++ b/internal/controllers/menu_controller.go @@ -17,6 +17,7 @@ func handleNavbar(this *beego.Controller) { this.Data["webApplicationName"] = configure.WebApplicationName this.Data["webApplicationAuthor"] = "CytusD " this.Data["webDescription"] = conf.String("webDescription") + this.Data["AlbumEnabled"] = conf.String("AlbumEnabled") sess := this.StartSession() if !session.SessionIslogged(sess) { this.Data["notLoggedIn"] = true diff --git a/views/UserSettings.html b/views/UserSettings.html index 9c16ea7..98424f1 100644 --- a/views/UserSettings.html +++ b/views/UserSettings.html @@ -175,6 +175,7 @@
修改绑定邮箱
+ {{if .AlbumEnabled}}
@@ -229,6 +230,7 @@
上传图片到相册
+ {{end}} diff --git a/views/tpls/navbar.html b/views/tpls/navbar.html index 0d50504..3905724 100644 --- a/views/tpls/navbar.html +++ b/views/tpls/navbar.html @@ -13,9 +13,11 @@
  • 商品列表
  • + {{if .AlbumEnabled}}
  • 相册
  • + {{end}} {{if not .notLoggedIn}}
  • 消息 diff --git a/views/tpls/serverinfoModal.html b/views/tpls/serverinfoModal.html index 2a73974..e1ce55c 100644 --- a/views/tpls/serverinfoModal.html +++ b/views/tpls/serverinfoModal.html @@ -70,7 +70,7 @@

    使用余额续费服务器

    更换预设服务器包

    您可以选择我们预设的一些服务器整合包来作为快捷启动选项
    - 一旦选择新的或与原来相同的整合包并点击“确认安装”按钮,我们将清空服务器数据并进行安装操作
    + 一旦选择新的或与原来相同的整合包并点击“确认安装”按钮,我们!!!将清空服务器数据!!!并进行安装操作
    由于这一过程不可逆,请您确认没有贵重数据或已备份