From 2943d73d494f372e7ef1880933d57cbec56d0863 Mon Sep 17 00:00:00 2001 From: Pomog Date: Sun, 7 Jan 2024 20:06:43 +0200 Subject: [PATCH] moderator --- README.md | 22 +++-- internal/handler/moderPanelHanlder.go | 51 ++++++++--- internal/handler/themeHandler.go | 3 + mainDB.db | Bin 327680 -> 327680 bytes ...0\275\320\260\321\201\321\216\320\272.jpe" | Bin 0 -> 4497 bytes static/post_images/yog.jpeg | Bin 0 -> 9398 bytes template/home.page.html | 7 +- template/moderMain.page.html | 63 ++++++++++++- template/theme.page.html | 86 ++++++++++-------- 9 files changed, 169 insertions(+), 63 deletions(-) create mode 100644 "static/ava/\320\256\321\200\320\270\320\271 \320\237\320\260\320\275\320\260\321\201\321\216\320\272.jpe" create mode 100644 static/post_images/yog.jpeg diff --git a/README.md b/README.md index 074e476..f1a9abf 100644 --- a/README.md +++ b/README.md @@ -18,15 +18,23 @@ This is a Web Application written in Golang, utilizing only standard [Go librari - [How to use Docker](docs/howToUsewDocker.md) ### User Management: -- User Registration: Users can create new accounts. -- Guest Registration: Allow guest users to access limited features or explore the platform without registration. -- Login System: Users can log in using their email and password credentials. +- **User Registration:** Users can create new accounts. +- **Guest Registration:** Allows guest users to access limited features or explore the platform without registration. +- **Login System:** Users can log in using their email and password credentials. +- The registered user can have types: user, moderator. +- To change the user type, registered users should use a Special Code in their personal cabinet. +#### User Types +- **Moderator:** Has special rights, including the ability to see all messages and change the classification for messages. ### Content Creation: -- Topic Creation: Users can create new discussion topics. - - Topic Creation with Image: Option to include images when creating topics. -- Post Creation: Users can contribute to discussions by creating posts. - - Post Creation with Image: Ability to attach images to posts. +- **Topic Creation:** Users can create new discussion topics. + - **Topic Creation with Image:** Option to include images when creating topics. +- **Post Creation:** Users can contribute to discussions by creating posts. + - **Post Creation with Image:** Ability to attach images to posts. +- Forum messages have classifications: unsorted, obscene, illegal, insulting, approved. +- Users without moderator rights can create unsorted messages. +- Users without moderator rights can see all their own messages and approved messages from other users. + ### Interaction Features: - Like/Dislike System: Users can like or dislike posts. diff --git a/internal/handler/moderPanelHanlder.go b/internal/handler/moderPanelHanlder.go index befc4e6..52f1110 100644 --- a/internal/handler/moderPanelHanlder.go +++ b/internal/handler/moderPanelHanlder.go @@ -39,22 +39,45 @@ func handlePostRequestModerPage(w http.ResponseWriter, r *http.Request, m *Repos } selectedCategory := r.FormValue("btnradio") - topicID, err := strconv.Atoi(r.FormValue("topicID")) - if err != nil { - setErrorAndRedirect(w, r, "Could not convert string into int "+err.Error(), "/error-page") - return - } - topic, err := m.DB.GetThreadByID(topicID) - if err != nil { - setErrorAndRedirect(w, r, "Could not get topic by id "+err.Error(), "/error-page") - return + + if r.FormValue("postID") != "" { + postID, err := strconv.Atoi(r.FormValue("postID")) + if err != nil { + setErrorAndRedirect(w, r, "Could not convert string into int "+err.Error(), "/error-page") + return + } + post, err := m.DB.GetPostByID(postID) + if err != nil { + setErrorAndRedirect(w, r, "Could not get post by id "+err.Error(), "/error-page") + return + } + cat := models.TextClassification(selectedCategory) + + err = m.DB.EditPostClassification(post, cat) + if err != nil { + setErrorAndRedirect(w, r, "Could not edit post classification "+err.Error(), "/error-page") + return + } } - cat := models.TextClassification(selectedCategory) - err = m.DB.EditTopicClassification(topic, cat) - if err != nil { - setErrorAndRedirect(w, r, "Could not edit topic classification "+err.Error(), "/error-page") - return + if r.FormValue("topicID") != "" { + topicID, err := strconv.Atoi(r.FormValue("topicID")) + if err != nil { + setErrorAndRedirect(w, r, "Could not convert string into int "+err.Error(), "/error-page") + return + } + topic, err := m.DB.GetThreadByID(topicID) + if err != nil { + setErrorAndRedirect(w, r, "Could not get topic by id "+err.Error(), "/error-page") + return + } + cat := models.TextClassification(selectedCategory) + + err = m.DB.EditTopicClassification(topic, cat) + if err != nil { + setErrorAndRedirect(w, r, "Could not edit topic classification "+err.Error(), "/error-page") + return + } } // Redirect back to the previous page (referer) diff --git a/internal/handler/themeHandler.go b/internal/handler/themeHandler.go index 365a6e0..16f0865 100644 --- a/internal/handler/themeHandler.go +++ b/internal/handler/themeHandler.go @@ -59,6 +59,8 @@ func (m *Repository) ThemeHandler(w http.ResponseWriter, r *http.Request) { return } + data["loggedAsID"] = visitorID + renderer.RendererTemplate(w, "theme.page.html", &models.TemplateData{ Data: data, }) @@ -250,6 +252,7 @@ func getPostsInfo(m *Repository, w http.ResponseWriter, r *http.Request, threadI info.UserPostsAmmount = userPostsAmount info.Likes = likes info.Dislikes = dislikes + info.Classification = post.Classification postsInfo = append(postsInfo, info) } diff --git a/mainDB.db b/mainDB.db index 738ec7374dec486503aee7ff499c34c5eacca8f1..1829a0eec29782e4b41751ac911408bb0e4ee9f2 100644 GIT binary patch delta 630 zcmX|;J#W)c6o&2CY2x(5RTPP#EnEZ$RjP{WrWyMKPWp4;~)O$!b+lzp5u{Ppw9akM5~^tFkPJyXm4; zGxP$sw4!P2THXXxD_MrFnGOas3&olV)~fVJYUFJvR|Cy*vbL6Ya<{coHmhrTUf0cn zT>{IoqmyS(7c&zj?Wc+77Y9_@|7j4M26=1VkJMLdv@cUNZ2h+Xhto=b>H7pt**y=aJ475_q^fl{11Y z;!_s3EXKWE)|hskkTel>d(FTDL>u6-zgqBcjf9v1a!ANRpcLr(|1=j=9syY#=VA|q zg!^3|+0X`$ACjXxfCD~ojZY>Xf2P|I)_@RAVLqGMT%MJ#=k#oM^=;x`tm}F}TR!E9z&@xP4=cwauNW_BQaP3<&Tm&0%3J^d delta 982 zcmYk4%}*0S7{+%?DU`3pz)g)Wk;Is=rQO|rdeDl|G=U%}7!wUncV~A8wmW5KmfBNW zi7{Lh(s1Cc2SbcTd+?5TZ~hnl0Un)gk$9M7^3FT+yuas}c6+wno;|!QA0J&=l8?W> z_^>!NEN#W)_tMsQY5daA;ZbL0=2ba1CUwgDS9MvQd`#=aEOmdVYpql&RpuP~oKPQ- z=fTR#>iWY6AS!Oi2x6Sg!7}DI7+7Qv1MxWp?qcu|$BcuI8w`+dL0Gq<3N#3JiQjK= zP>uKwG-%*iDR|-{4)~=>cvQ6T9`FJW5krVsdas>YRmH;mgz?X@Sk%K{7 zfbLKAe&oSjM8X;n@i5eB0|$2KL4b$_Rmzxv{>OtC`mh$ZG3s-;q<@Xt!b5S{bcKi5 zcOt~d6-FGN*u+FW2V|PGR`&>VBWSQ`0Cf*FaVuaT_D)DVi>09ApJ%|pBRd%WoAzQN zLEJwZj2+p-n<7%7-2}uKHHpZ=>SqBiaa`4l>;{wiQPc|%;N6e}(U6P>Ez#=`Q=HPk zBEH~?zCtuS52$G27}Z3EJ0Oy0p=n~qggruO;6lHZRyh(b?IABjRSye+1_~mYi%hbR zDVB_MDPzd7MaG4Sxmc%+Z;|d>o=9X;+jZ>pHVdaCGY3mUQDlctMPwW2fAu+A>;2ZN z@sUYMk|vc-Z{*IdlAKCN$x&GzpXqj1_a|b?sigc;PL-B&vp4B}Ynt^ln&7rs?ZzQy$ZRQG@v?>D5t47u;s0F)VsJfwN zjY3v4a_M64bnDsl?3pyVJN7OHqn}2##Gm2q_^fnx)cM$3V_zo5Ur!8=N(VP|xqPjs y%%fO$o?ZXej!#d-la<)mdh&D9PgZ*6JB6e?zh60dQ#p~viitJ!y>b%&ZvO=lJv^ZR diff --git "a/static/ava/\320\256\321\200\320\270\320\271 \320\237\320\260\320\275\320\260\321\201\321\216\320\272.jpe" "b/static/ava/\320\256\321\200\320\270\320\271 \320\237\320\260\320\275\320\260\321\201\321\216\320\272.jpe" new file mode 100644 index 0000000000000000000000000000000000000000..ec78b48bf7ee2575e012872a6c68f597dbb598af GIT binary patch literal 4497 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 EU$YxToB#j- literal 0 HcmV?d00001 diff --git a/template/home.page.html b/template/home.page.html index 7439f9d..87e4fe3 100644 --- a/template/home.page.html +++ b/template/home.page.html @@ -1,6 +1,7 @@ {{template "body" .}} {{define "centralPart"}} +{{$loggedID := index .Data "loggedAsID"}}
@@ -8,7 +9,9 @@ {{$threadinfo := index .Data "threads"}} - {{$loggedID := index .Data "loggedAsID"}} + {{ range $threadinfo }} {{ if or (eq .UserID $loggedID) (eq .Classification "approved") }} @@ -83,7 +86,7 @@

What this topic will {{ $lastPostShorten := shortenPost .Posts}}
{{ $lastPostShorten}} {{ else }} - Be the first one to add post here... +

Be the first one to add post here...
{{end}} {{ $numOfPosts := numberOfPosts .Posts }} diff --git a/template/moderMain.page.html b/template/moderMain.page.html index 424500e..0eb13c0 100644 --- a/template/moderMain.page.html +++ b/template/moderMain.page.html @@ -1,6 +1,8 @@ {{template "body" .}} {{define "centralPart"}} + {{$posts := index .Data "posts"}} + {{$topics := index .Data "topics"}}
Moderator Main page
+ {{ range $posts }} + {{$postsCategory := .Classification}} + {{$postID := .ID}} + + + + + + + + +
+ + {{ end }} + + + {{ end }} + + {{if $topics}}
@@ -39,7 +97,6 @@

Select Thread Category:


Category: {{ .Category}}
{{ .Subject }} - diff --git a/template/theme.page.html b/template/theme.page.html index 9d052b9..4204bf2 100644 --- a/template/theme.page.html +++ b/template/theme.page.html @@ -5,6 +5,7 @@ {{end}} {{define "centralPart"}} {{$threadID :=index .Data "mainThreadID"}} +{{$loggedID := index .Data "loggedAsID"}}
@@ -13,7 +14,9 @@ {{ if $threadID}}
+ {{ if ne 1 $loggedID}} + {{end}}
{{ end }}
@@ -73,12 +76,13 @@

Topic:

{{ end }}

{{index .Data "mainThreadName"}}
- + {{ if and (ne $loggedID 1) (eq $creatorID $loggedID) }}
+ {{end}}
Created: {{index .Data "mainThreadCreatedTime"}}
@@ -94,44 +98,52 @@

Topic:

{{$postinfo := index .Data "posts"}} {{ range $postinfo }} - - - - + + + - + {{ if .Image }} + post_img + {{ end }}

+ + {{ .Content }}  + {{ if and (ne $loggedID 1) (eq $postCreatorID $loggedID) }} + + + + + {{end}} +
+ Posted: {{ .Created }}
+
+ {{ if ne 1 $loggedID}} +
+ + + +    +
+ + + + {{ end }} +
+
+ + + {{ end }} {{ end }}