diff options
| author | realtradam <[email protected]> | 2024-07-14 23:43:35 -0400 |
|---|---|---|
| committer | realtradam <[email protected]> | 2024-07-14 23:43:35 -0400 |
| commit | 0081ab9926c486beb3033791e9e8f946b3c8b48a (patch) | |
| tree | ddd52a3454d630b43946a3271c5fac2880d1f722 /src/main/java/com/blog/web/controllers/ArticleController.java | |
| parent | 16aea3767fc42f4baa30f7fc466e7a8851b0ecbb (diff) | |
| download | spring-blog-0081ab9926c486beb3033791e9e8f946b3c8b48a.tar.gz spring-blog-0081ab9926c486beb3033791e9e8f946b3c8b48a.zip | |
add auth for editing and deleting posts
Diffstat (limited to 'src/main/java/com/blog/web/controllers/ArticleController.java')
| -rw-r--r-- | src/main/java/com/blog/web/controllers/ArticleController.java | 39 |
1 files changed, 31 insertions, 8 deletions
diff --git a/src/main/java/com/blog/web/controllers/ArticleController.java b/src/main/java/com/blog/web/controllers/ArticleController.java index 9af5b92..d1bfcce 100644 --- a/src/main/java/com/blog/web/controllers/ArticleController.java +++ b/src/main/java/com/blog/web/controllers/ArticleController.java @@ -12,7 +12,6 @@ import org.springframework.ui.Model; import org.springframework.validation.BindingResult; import org.springframework.web.bind.annotation.*; -import java.time.LocalDateTime; import java.util.List; @Controller @@ -27,13 +26,8 @@ public class ArticleController { @GetMapping("/articles") public String listArticles(Model model) { - UserEntity user = new UserEntity(); List<ArticleDto> articles = articleService.findAllArticles(); - String username = SecurityUtil.getSessionUser(); - if(username != null) { - user = userService.findByUsername(username); - model.addAttribute("user", user); - } + UserEntity user = getLoggedInUser(); model.addAttribute("user", user); model.addAttribute("articles", articles); return "index"; @@ -43,11 +37,15 @@ public class ArticleController { public String showArticle(@PathVariable("articleId") long articleId, Model model) { ArticleDto articleDto = articleService.findArticleById(articleId); model.addAttribute("article", articleDto); + UserEntity user = getLoggedInUser(); + model.addAttribute("user", user); return "articles/show"; } @GetMapping("/articles/new") public String createArticleForm(Model model) { + UserEntity user = getLoggedInUser(); + model.addAttribute("user", user); Article article = new Article(); model.addAttribute("article", article); return "articles/new"; @@ -65,14 +63,30 @@ public class ArticleController { return "redirect:/articles"; } + private UserEntity getLoggedInUser() { + UserEntity user = new UserEntity(); + String username = SecurityUtil.getSessionUser(); + if(username != null) { + user = userService.findByUsername(username); + } + return user; + } + @GetMapping("/articles/delete/{articleId}") public String deleteArticle(@PathVariable("articleId") Long articleId) { - articleService.delete(articleId); + UserEntity user = getLoggedInUser(); + ArticleDto article = articleService.findArticleById(articleId); + UserEntity owner = article.getCreatedBy(); + if(owner.getId() == user.getId()) { + articleService.delete(articleId); + } return "redirect:/articles"; } @GetMapping("/articles/edit/{articleId}") public String editArticleForm(@PathVariable("articleId") long articleId, Model model) { + UserEntity user = getLoggedInUser(); + model.addAttribute("user", user); ArticleDto articleDto = articleService.findArticleById(articleId); model.addAttribute("article", articleDto); return "articles/edit"; @@ -92,11 +106,20 @@ public class ArticleController { @GetMapping("/articles/search") public String searchArticle(@RequestParam(value = "search") String search, Model model) { + UserEntity user = getLoggedInUser(); + model.addAttribute("user", user); List<ArticleDto> articles = articleService.searchArticles(search); model.addAttribute("articles", articles); return "index"; } + @GetMapping("/userlogin") + public String login(Model model) { + UserEntity user = getLoggedInUser(); + model.addAttribute("user", user); + return "auth/login"; + } + @GetMapping("/") public String getArticles() { return "redirect:/articles"; |
