cleaned up code format

This commit is contained in:
durn
2026-03-04 01:27:15 -07:00
parent 0a38aa3ded
commit 4bdb449f47
29 changed files with 865 additions and 822 deletions
@@ -29,42 +29,40 @@ public class RecipeController {
this.recipeService = recipeService;
}
//build create recipe REST API
// build create recipe REST API
@PostMapping
public ResponseEntity<RecipeDto> saveUser(@RequestBody Recipe recipe){
public ResponseEntity<RecipeDto> saveUser(@RequestBody Recipe recipe) {
RecipeDto recipeDto = recipeService.convertToDto(recipe);
return new ResponseEntity<RecipeDto>(recipeService.saveRecipe(recipeDto), HttpStatus.CREATED);
}
//build get all recipes REST API
// build get all recipes REST API
@GetMapping
public List<RecipeDto> getAllRecipes(){
public List<RecipeDto> getAllRecipes() {
return recipeService.getAllRecipes();
}
//build get recipe by id REST API
// build get recipe by id REST API
// http://localhost:8080/api/recipes/(id number goes here)
@GetMapping("{id}")
public ResponseEntity<RecipeDto> getRecipeById(@PathVariable("id") Integer recipeId){
public ResponseEntity<RecipeDto> getRecipeById(@PathVariable("id") Integer recipeId) {
return new ResponseEntity<RecipeDto>(recipeService.getRecipeById(recipeId), HttpStatus.OK);
}
//build update recipe REST API
//http://localhost:8080/api/recipes/(id number goes here)
// build update recipe REST API
// http://localhost:8080/api/recipes/(id number goes here)
@PutMapping("{id}")
public ResponseEntity<RecipeDto> updateUser(@PathVariable("id") Integer recipeId, @RequestBody Recipe recipe){
public ResponseEntity<RecipeDto> updateUser(@PathVariable("id") Integer recipeId, @RequestBody Recipe recipe) {
RecipeDto recipeDto = recipeService.convertToDto(recipe);
return new ResponseEntity<RecipeDto>(recipeService.updateRecipe(recipeDto, recipeId), HttpStatus.OK);
}
//build delete recipe REST API
//http://localhost:8080/api/recipes/(id number goes here)
// build delete recipe REST API
// http://localhost:8080/api/recipes/(id number goes here)
@DeleteMapping("{id}")
public ResponseEntity<String> deleteUser(@PathVariable("id") Integer recipeId){
public ResponseEntity<String> deleteUser(@PathVariable("id") Integer recipeId) {
recipeService.deleteRecipe(recipeId);
return new ResponseEntity<String>("Recipe deleted succesfully!", HttpStatus.OK);
}
}
@@ -28,52 +28,52 @@ public class UserController {
this.userService = userService;
}
//build create user REST API
// build create user REST API
@PostMapping
public ResponseEntity<User> saveUser(@RequestBody User user){
public ResponseEntity<User> saveUser(@RequestBody User user) {
return new ResponseEntity<User>(userService.saveUser(user), HttpStatus.CREATED);
}
//build get all users REST API
// build get all users REST API
@GetMapping
public List<UserDto> getAllUsers(){
public List<UserDto> getAllUsers() {
return userService.getAllUsers();
}
//build get user by id REST API
// build get user by id REST API
// http://localhost:8080/api/users/(id number goes here)
@GetMapping("{id}")
public ResponseEntity<UserDto> getUserById(@PathVariable("id") Integer userId){
public ResponseEntity<UserDto> getUserById(@PathVariable("id") Integer userId) {
return new ResponseEntity<UserDto>(userService.getUserById(userId), HttpStatus.OK);
}
//build create favorite REST API
// build create favorite REST API
@PostMapping("/{userId}/favorites/{recipeId}")
public ResponseEntity<UserDto> saveFavorite( @PathVariable Integer userId, @PathVariable Integer recipeId) {
public ResponseEntity<UserDto> saveFavorite(@PathVariable Integer userId, @PathVariable Integer recipeId) {
UserDto updatedUser = userService.saveFavorite(userId, recipeId);
return new ResponseEntity<>(updatedUser, HttpStatus.OK);
}
//build update user REST API
// build update user REST API
// http://localhost:8080/api/users/(id number goes here)
@PutMapping("{id}")
public ResponseEntity<UserDto> updateUser(@PathVariable("id") Integer userId, @RequestBody User user){
public ResponseEntity<UserDto> updateUser(@PathVariable("id") Integer userId, @RequestBody User user) {
return new ResponseEntity<UserDto>(userService.updateUser(user, userId), HttpStatus.OK);
}
//build delete user REST API
// build delete user REST API
@DeleteMapping("{id}")
public ResponseEntity<String> deleteUser(@PathVariable("id") Integer userId){
public ResponseEntity<String> deleteUser(@PathVariable("id") Integer userId) {
userService.deleteUser(userId);
return new ResponseEntity<String>("User deleted succesfully!", HttpStatus.OK);
}
//build delete favorite REST API
// build delete favorite REST API
@DeleteMapping("/{userId}/favorites/{recipeId}")
public ResponseEntity<String> deleteFavorite( @PathVariable Integer userId, @PathVariable Integer recipeId) {
public ResponseEntity<String> deleteFavorite(@PathVariable Integer userId, @PathVariable Integer recipeId) {
userService.deleteFavorite(userId, recipeId);
return new ResponseEntity<String>("Favorite deleted succesfully!", HttpStatus.OK);
@@ -3,8 +3,6 @@ package com.example.demo.dto;
public class ImageDto {
String imageUrl;
public ImageDto() {
super();
}
@@ -22,5 +20,4 @@ public class ImageDto {
this.imageUrl = imageUrl;
}
}
@@ -17,15 +17,13 @@ public class RecipeDto {
private List<ImageDto> images;
private List<TagDto> tags;
public RecipeDto() {
super();
}
public RecipeDto(String title, String description, Integer prepTimeMinutes, Integer cookTimeMinutes,
Integer servings, UserDto userDto, String status, List<RecipeIngredientDto> ingredients, List<StepDto> steps, List<ImageDto> images, List<TagDto> tags) {
Integer servings, UserDto userDto, String status, List<RecipeIngredientDto> ingredients,
List<StepDto> steps, List<ImageDto> images, List<TagDto> tags) {
super();
this.title = title;
this.description = description;
@@ -45,42 +43,55 @@ public class RecipeDto {
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public Integer getPrepTimeMinutes() {
return prepTimeMinutes;
}
public void setPrepTimeMinutes(Integer prepTimeMinutes) {
this.prepTimeMinutes = prepTimeMinutes;
}
public Integer getCookTimeMinutes() {
return cookTimeMinutes;
}
public void setCookTimeMinutes(Integer cookTimeMinutes) {
this.cookTimeMinutes = cookTimeMinutes;
}
public Integer getServings() {
return servings;
}
public void setServings(Integer servings) {
this.servings = servings;
}
public String getStatus() {
return status;
}
public void setStatus(String status) {
this.status = status;
}
public List<RecipeIngredientDto> getIngredients() {
return ingredients;
}
public void setIngredients(List<RecipeIngredientDto> ingredients) {
this.ingredients = ingredients;
}
@@ -93,7 +104,6 @@ public class RecipeDto {
this.steps = steps;
}
public List<ImageDto> getImages() {
return images;
}
@@ -102,7 +112,6 @@ public class RecipeDto {
this.images = images;
}
public List<TagDto> getTags() {
return tags;
}
@@ -119,5 +128,4 @@ public class RecipeDto {
this.userDto = userDto;
}
}
@@ -8,10 +8,6 @@ public class RecipeIngredientDto {
private String unit;
private String notes;
public RecipeIngredientDto() {
super();
}
@@ -28,24 +24,31 @@ public class RecipeIngredientDto {
public String getIngredientName() {
return ingredientName;
}
public void setIngredientName(String ingredientName) {
this.ingredientName = ingredientName;
}
public BigDecimal getQuantity() {
return quantity;
}
public void setQuantity(BigDecimal quantity) {
this.quantity = quantity;
}
public String getUnit() {
return unit;
}
public void setUnit(String unit) {
this.unit = unit;
}
public String getNotes() {
return notes;
}
public void setNotes(String notes) {
this.notes = notes;
}
@@ -4,7 +4,8 @@ public class StepDto {
private Integer stepNumber;
private String instruction;
public StepDto() {}
public StepDto() {
}
public StepDto(Integer stepNumber, String instruction) {
this.stepNumber = stepNumber;
@@ -7,21 +7,15 @@ public class TagDto {
super();
}
public TagDto(String name) {
super();
this.name = name;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@@ -5,7 +5,8 @@ public class UserDto {
private String username;
private String email;
public UserDto() {}
public UserDto() {
}
public UserDto(Integer id, String username, String email) {
this.id = id;
@@ -37,5 +38,4 @@ public class UserDto {
this.email = email;
}
}
@@ -6,7 +6,7 @@ import lombok.EqualsAndHashCode;
import java.time.LocalDateTime;
@Entity
@Table(name = "recipe_images") // keep table name the same
@Table(name = "recipe_images")
public class Image {
@Id
@@ -24,7 +24,8 @@ public class Image {
@Column(name = "created_at")
private LocalDateTime createdAt;
public Image() {}
public Image() {
}
public Image(Recipe recipe, String imageUrl) {
this.recipe = recipe;
@@ -33,8 +34,13 @@ public class Image {
}
// Getters and setters
public Integer getId() { return id; }
public void setId(Integer id) { this.id = id; }
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public Recipe getRecipe() {
return recipe;
@@ -44,9 +50,19 @@ public class Image {
this.recipe = recipe;
}
public String getImageUrl() { return imageUrl; }
public void setImageUrl(String imageUrl) { this.imageUrl = imageUrl; }
public String getImageUrl() {
return imageUrl;
}
public LocalDateTime getCreatedAt() { return createdAt; }
public void setCreatedAt(LocalDateTime createdAt) { this.createdAt = createdAt; }
public void setImageUrl(String imageUrl) {
this.imageUrl = imageUrl;
}
public LocalDateTime getCreatedAt() {
return createdAt;
}
public void setCreatedAt(LocalDateTime createdAt) {
this.createdAt = createdAt;
}
}
@@ -16,36 +16,42 @@ import jakarta.persistence.CascadeType;
import jakarta.persistence.Column;
@Entity
@Table(name = "ingredients", uniqueConstraints = {
@UniqueConstraint(columnNames = "name")
})
@Table(name = "ingredients", uniqueConstraints = { @UniqueConstraint(columnNames = "name") })
public class Ingredient {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
@Column(nullable = false, unique = true)
private String name;
@OneToMany(mappedBy = "ingredient")
private Set<RecipeIngredient> recipeIngredients = new HashSet<>();
// Default constructor required by JPA
public Ingredient() {}
public Ingredient() {
}
// Convenience constructor
public Ingredient(String name) {
this.name = name;
}
// Getters and setters
public Integer getId() { return id; }
public void setId(Integer id) { this.id = id; }
public Integer getId() {
return id;
}
public String getName() { return name; }
public void setName(String name) { this.name = name; }
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Set<RecipeIngredient> getRecipeIngredients() {
return recipeIngredients;
@@ -1,6 +1,7 @@
package com.example.demo.entity;
import jakarta.persistence.*;
import jakarta.validation.constraints.NotBlank;
import lombok.EqualsAndHashCode;
import java.math.BigDecimal;
@@ -16,6 +17,7 @@ public class Recipe {
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
@NotBlank(message = "Please provide a recipe title")
private String title;
@Column(columnDefinition = "TEXT")
@@ -35,7 +37,6 @@ public class Recipe {
@EqualsAndHashCode.Include
private User user;
// Recipe ingredients relationship
@OneToMany(mappedBy = "recipe", cascade = CascadeType.ALL, orphanRemoval = true, fetch = FetchType.LAZY)
private Set<RecipeIngredient> recipeIngredients = new HashSet<>();
@@ -50,22 +51,19 @@ public class Recipe {
// Recipe Tag relationship and also junction table
@ManyToMany(fetch = FetchType.LAZY)
@JoinTable(name = "recipe_tags",
joinColumns = {@JoinColumn(name = "recipe_id")},
inverseJoinColumns = {@JoinColumn(name = "tag_id")})
@JoinTable(name = "recipe_tags", joinColumns = { @JoinColumn(name = "recipe_id") }, inverseJoinColumns = {
@JoinColumn(name = "tag_id") })
private Set<Tag> tags = new HashSet<>();
// User is the manager for this relationship
@ManyToMany(fetch = FetchType.LAZY, mappedBy = "FavRecipes")
private Set<User> users = new HashSet<>();
public Recipe() {
}
// Default constructor
public Recipe() {}
// Convenience constructor
public Recipe(String title, String description, Integer prepTimeMinutes, Integer cookTimeMinutes,
Integer servings, User user, String status) {
public Recipe(String title, String description, Integer prepTimeMinutes, Integer cookTimeMinutes, Integer servings,
User user, String status) {
this.title = title;
this.description = description;
this.prepTimeMinutes = prepTimeMinutes;
@@ -77,34 +75,14 @@ public class Recipe {
this.updatedAt = LocalDateTime.now();
}
// Helper method to add an ingredient
public void addIngredient(Ingredient ingredient, BigDecimal quantity, String unit, String notes) {
RecipeIngredient recipeIngredient = new RecipeIngredient(this, ingredient, quantity, unit, notes);
recipeIngredients.add(recipeIngredient);
ingredient.getRecipeIngredients().add(recipeIngredient);
}
public void removeIngredient(Ingredient ingredient) {
RecipeIngredient remove = null;
for (RecipeIngredient recipeIngredient : recipeIngredients) {
if (recipeIngredient.getIngredient().equals(ingredient)) {
remove = recipeIngredient;
break;
}
}
if (remove != null) {
recipeIngredients.remove(remove);
ingredient.getRecipeIngredients().remove(remove);
remove.setRecipe(null);
remove.setIngredient(null);
}
}
// Getters and setters
public Integer getId() { return id; }
public void setId(Integer id) { this.id = id; }
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public User getUser() {
return user;
@@ -114,33 +92,77 @@ public class Recipe {
this.user = user;
}
public String getTitle() { return title; }
public void setTitle(String title) { this.title = title; }
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getDescription() { return description; }
public void setDescription(String description) { this.description = description; }
public String getDescription() {
return description;
}
public Integer getPrepTimeMinutes() { return prepTimeMinutes; }
public void setPrepTimeMinutes(Integer prepTimeMinutes) { this.prepTimeMinutes = prepTimeMinutes; }
public void setDescription(String description) {
this.description = description;
}
public Integer getCookTimeMinutes() { return cookTimeMinutes; }
public void setCookTimeMinutes(Integer cookTimeMinutes) { this.cookTimeMinutes = cookTimeMinutes; }
public Integer getPrepTimeMinutes() {
return prepTimeMinutes;
}
public Integer getServings() { return servings; }
public void setServings(Integer servings) { this.servings = servings; }
public void setPrepTimeMinutes(Integer prepTimeMinutes) {
this.prepTimeMinutes = prepTimeMinutes;
}
public String getStatus() { return status; }
public void setStatus(String status) { this.status = status; }
public Integer getCookTimeMinutes() {
return cookTimeMinutes;
}
public LocalDateTime getCreatedAt() { return createdAt; }
public void setCreatedAt(LocalDateTime createdAt) { this.createdAt = createdAt; }
public void setCookTimeMinutes(Integer cookTimeMinutes) {
this.cookTimeMinutes = cookTimeMinutes;
}
public LocalDateTime getUpdatedAt() { return updatedAt; }
public void setUpdatedAt(LocalDateTime updatedAt) { this.updatedAt = updatedAt; }
public Integer getServings() {
return servings;
}
public Set<RecipeIngredient> getRecipeIngredients() { return recipeIngredients; }
public void setRecipeIngredients(Set<RecipeIngredient> recipeIngredients) { this.recipeIngredients = recipeIngredients; }
public void setServings(Integer servings) {
this.servings = servings;
}
public String getStatus() {
return status;
}
public void setStatus(String status) {
this.status = status;
}
public LocalDateTime getCreatedAt() {
return createdAt;
}
public void setCreatedAt(LocalDateTime createdAt) {
this.createdAt = createdAt;
}
public LocalDateTime getUpdatedAt() {
return updatedAt;
}
public void setUpdatedAt(LocalDateTime updatedAt) {
this.updatedAt = updatedAt;
}
public Set<RecipeIngredient> getRecipeIngredients() {
return recipeIngredients;
}
public void setRecipeIngredients(Set<RecipeIngredient> recipeIngredients) {
this.recipeIngredients = recipeIngredients;
}
public Set<Step> getSteps() {
return steps;
@@ -173,7 +195,4 @@ public class Recipe {
public void setUsers(Set<User> users) {
this.users = users;
}
}
@@ -5,11 +5,9 @@ import java.math.BigDecimal;
import lombok.EqualsAndHashCode;
@Entity
@Table(name = "recipe_ingredient_junction",
uniqueConstraints = {@UniqueConstraint(columnNames = {"recipe_id", "ingredient_id"})})
@EqualsAndHashCode(
onlyExplicitlyIncluded = true
)
@Table(name = "recipe_ingredient_junction", uniqueConstraints = {
@UniqueConstraint(columnNames = { "recipe_id", "ingredient_id" }) })
@EqualsAndHashCode(onlyExplicitlyIncluded = true)
public class RecipeIngredient {
@Id
@@ -32,7 +30,8 @@ public class RecipeIngredient {
private String notes;
public RecipeIngredient() {}
public RecipeIngredient() {
}
public RecipeIngredient(Recipe recipe, Ingredient ingredient, BigDecimal quantity, String unit, String notes) {
this.recipe = recipe;
@@ -43,21 +42,51 @@ public class RecipeIngredient {
}
// Getters and setters
public Integer getId() { return id; }
public void setId(Integer id) { this.id = id; }
public Integer getId() {
return id;
}
public Recipe getRecipe() { return recipe; }
public void setRecipe(Recipe recipe) { this.recipe = recipe; }
public void setId(Integer id) {
this.id = id;
}
public Ingredient getIngredient() { return ingredient; }
public void setIngredient(Ingredient ingredient) { this.ingredient = ingredient; }
public Recipe getRecipe() {
return recipe;
}
public BigDecimal getQuantity() { return quantity; }
public void setQuantity(BigDecimal quantity) { this.quantity = quantity; }
public void setRecipe(Recipe recipe) {
this.recipe = recipe;
}
public String getUnit() { return unit; }
public void setUnit(String unit) { this.unit = unit; }
public Ingredient getIngredient() {
return ingredient;
}
public String getNotes() { return notes; }
public void setNotes(String notes) { this.notes = notes; }
public void setIngredient(Ingredient ingredient) {
this.ingredient = ingredient;
}
public BigDecimal getQuantity() {
return quantity;
}
public void setQuantity(BigDecimal quantity) {
this.quantity = quantity;
}
public String getUnit() {
return unit;
}
public void setUnit(String unit) {
this.unit = unit;
}
public String getNotes() {
return notes;
}
public void setNotes(String notes) {
this.notes = notes;
}
}
@@ -16,7 +16,8 @@ public class RecipeTagId implements Serializable {
@Column(name = "tag_id")
private Integer tagId;
public RecipeTagId() {}
public RecipeTagId() {
}
public RecipeTagId(Integer recipeId, Integer tagId) {
this.recipeId = recipeId;
@@ -39,14 +40,14 @@ public class RecipeTagId implements Serializable {
this.tagId = tagId;
}
// REQUIRED for composite keys
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof RecipeTagId)) return false;
if (this == o)
return true;
if (!(o instanceof RecipeTagId))
return false;
RecipeTagId that = (RecipeTagId) o;
return Objects.equals(recipeId, that.recipeId) &&
Objects.equals(tagId, that.tagId);
return Objects.equals(recipeId, that.recipeId) && Objects.equals(tagId, that.tagId);
}
@Override
@@ -22,7 +22,8 @@ public class Step {
@EqualsAndHashCode.Include
private Recipe recipe;
public Step() {}
public Step() {
}
public Step(Recipe recipe, Integer stepNumber, String instruction) {
this.recipe = recipe;
@@ -31,8 +32,13 @@ public class Step {
}
// Getters and setters
public Integer getId() { return id; }
public void setId(Integer id) { this.id = id; }
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public Recipe getRecipe() {
return recipe;
@@ -42,9 +48,19 @@ public class Step {
this.recipe = recipe;
}
public Integer getStepNumber() { return stepNumber; }
public void setStepNumber(Integer stepNumber) { this.stepNumber = stepNumber; }
public Integer getStepNumber() {
return stepNumber;
}
public String getInstruction() { return instruction; }
public void setInstruction(String instruction) { this.instruction = instruction; }
public void setStepNumber(Integer stepNumber) {
this.stepNumber = stepNumber;
}
public String getInstruction() {
return instruction;
}
public void setInstruction(String instruction) {
this.instruction = instruction;
}
}
@@ -20,8 +20,8 @@ public class Tag {
@ManyToMany(fetch = FetchType.LAZY, mappedBy = "tags")
private Set<Recipe> recipes = new HashSet<>();
// Required by JPA
public Tag() {}
public Tag() {
}
public Tag(String name) {
this.name = name;
@@ -52,5 +52,4 @@ public class Tag {
this.recipes = recipes;
}
}
@@ -43,13 +43,12 @@ public class User {
// Favorite relationship and also junction table
@ManyToMany(fetch = FetchType.LAZY)
@JoinTable(name = "favorites",
joinColumns = {@JoinColumn(name = "userId")},
inverseJoinColumns = {@JoinColumn(name = "recipeId")})
@JoinTable(name = "favorites", joinColumns = { @JoinColumn(name = "userId") }, inverseJoinColumns = {
@JoinColumn(name = "recipeId") })
private Set<Recipe> FavRecipes = new HashSet<>();
// Constructors
public User() {}
public User() {
}
public User(String username, String role, String email, String hashedpassword, LocalDateTime createdAt) {
this.username = username;
@@ -59,24 +58,53 @@ public class User {
this.createdAt = createdAt;
}
public Integer getId() {
return id;
}
public Integer getId() { return id; }
public void setId(Integer id) { this.id = id; }
public void setId(Integer id) {
this.id = id;
}
public String getUsername() { return username; }
public void setUsername(String username) { this.username = username; }
public String getUsername() {
return username;
}
public String getRole() { return role; }
public void setRole(String role) { this.role = role; }
public void setUsername(String username) {
this.username = username;
}
public String getEmail() { return email; }
public void setEmail(String email) { this.email = email; }
public String getRole() {
return role;
}
public String getHashedpassword() { return hashedpassword; }
public void setHashedpassword(String hashedpassword) { this.hashedpassword = hashedpassword; }
public void setRole(String role) {
this.role = role;
}
public LocalDateTime getCreatedAt() { return createdAt; }
public void setCreatedAt(LocalDateTime createdAt) { this.createdAt = createdAt; }
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public String getHashedpassword() {
return hashedpassword;
}
public void setHashedpassword(String hashedpassword) {
this.hashedpassword = hashedpassword;
}
public LocalDateTime getCreatedAt() {
return createdAt;
}
public void setCreatedAt(LocalDateTime createdAt) {
this.createdAt = createdAt;
}
public Set<Recipe> getFavRecipes() {
return FavRecipes;
@@ -86,5 +114,4 @@ public class User {
FavRecipes = favRecipes;
}
}
@@ -3,8 +3,8 @@ package com.example.demo.exception;
import org.springframework.http.HttpStatus;
import org.springframework.web.bind.annotation.ResponseStatus;
@ResponseStatus (value = HttpStatus.NOT_FOUND)
public class NotFoundException extends RuntimeException{
@ResponseStatus(value = HttpStatus.NOT_FOUND)
public class NotFoundException extends RuntimeException {
private static final long serialVersionUID = 1l;
private String resourceName;
@@ -26,7 +26,6 @@ public class NotFoundException extends RuntimeException{
return fieldName;
}
public Object getFieldValue() {
return fieldValue;
}
@@ -5,7 +5,6 @@ import com.example.demo.entity.Image;
import java.util.List;
public interface ImageRepo extends JpaRepository<Image, Integer> {
}
@@ -5,7 +5,6 @@ import java.util.Optional;
import org.springframework.data.jpa.repository.JpaRepository;
import com.example.demo.entity.Ingredient;
public interface IngredientRepo extends JpaRepository<Ingredient, Integer> {
Optional<Ingredient> findByName(String name);
}
@@ -3,7 +3,6 @@ package com.example.demo.repository;
import org.springframework.data.jpa.repository.JpaRepository;
import com.example.demo.entity.Recipe;
public interface RecipeRepo extends JpaRepository<Recipe, Integer> {
}
@@ -1,6 +1,5 @@
package com.example.demo.repository;
import org.springframework.data.jpa.repository.JpaRepository;
import com.example.demo.entity.RecipeTag;
import com.example.demo.entity.RecipeTagId;
@@ -8,5 +8,4 @@ import java.util.List;
public interface StepRepo extends JpaRepository<Step, Integer> {
}
@@ -31,18 +31,19 @@ import com.example.demo.service.RecipeService;
import jakarta.transaction.Transactional;
@Service
public class RecipeServiceImpl implements RecipeService{
public class RecipeServiceImpl implements RecipeService {
private RecipeRepo recipeRepository;
private IngredientRepo ingredientRepository;
private RecipeIngredientRepo recipeIngredientRepository;
private UserRepo userRepository;
private StepRepo stepRepository;
private ImageRepo imageRepository;
private TagRepo tagRepository;
private RecipeRepo recipeRepository;
private IngredientRepo ingredientRepository;
private RecipeIngredientRepo recipeIngredientRepository;
private UserRepo userRepository;
private StepRepo stepRepository;
private ImageRepo imageRepository;
private TagRepo tagRepository;
public RecipeServiceImpl(RecipeRepo recipeRepository, IngredientRepo ingredientRepository, RecipeIngredientRepo recipeIngredientRepository, UserRepo userRepository, StepRepo stepRepository, ImageRepo imageRepository, TagRepo tagRepository) {
public RecipeServiceImpl(RecipeRepo recipeRepository, IngredientRepo ingredientRepository,
RecipeIngredientRepo recipeIngredientRepository, UserRepo userRepository, StepRepo stepRepository,
ImageRepo imageRepository, TagRepo tagRepository) {
super();
this.recipeRepository = recipeRepository;
this.ingredientRepository = ingredientRepository;
@@ -55,48 +56,23 @@ private TagRepo tagRepository;
public RecipeDto convertToDto(Recipe recipe) {
List<RecipeIngredientDto> ingredientDtos = recipe.getRecipeIngredients().stream()
.map(ri -> new RecipeIngredientDto(
ri.getIngredient().getName(),
ri.getQuantity(),
ri.getUnit(),
ri.getNotes()
))
.map(ri -> new RecipeIngredientDto(ri.getIngredient().getName(), ri.getQuantity(), ri.getUnit(),
ri.getNotes()))
.toList();
List<StepDto> stepDtos = recipe.getSteps().stream()
.map(ri -> new StepDto(
ri.getStepNumber(),
ri.getInstruction()
))
.toList();
.map(ri -> new StepDto(ri.getStepNumber(), ri.getInstruction())).toList();
List<ImageDto> imageDtos = recipe.getImages().stream()
.map(ri -> new ImageDto(
ri.getImageUrl()
))
.toList();
List<ImageDto> imageDtos = recipe.getImages().stream().map(ri -> new ImageDto(ri.getImageUrl())).toList();
List<TagDto> tagDtos = recipe.getTags().stream()
.map(ri -> new TagDto(
ri.getName()
))
.toList();
List<TagDto> tagDtos = recipe.getTags().stream().map(ri -> new TagDto(ri.getName())).toList();
UserDto userDto = new UserDto(recipe.getUser().getId(), recipe.getUser().getUsername(), recipe.getUser().getEmail());
UserDto userDto = new UserDto(recipe.getUser().getId(), recipe.getUser().getUsername(),
recipe.getUser().getEmail());
return new RecipeDto(
recipe.getTitle(),
recipe.getDescription(),
recipe.getPrepTimeMinutes(),
recipe.getCookTimeMinutes(),
recipe.getServings(),
userDto,
recipe.getStatus(),
ingredientDtos,
stepDtos,
imageDtos,
tagDtos
);
return new RecipeDto(recipe.getTitle(), recipe.getDescription(), recipe.getPrepTimeMinutes(),
recipe.getCookTimeMinutes(), recipe.getServings(), userDto, recipe.getStatus(), ingredientDtos,
stepDtos, imageDtos, tagDtos);
}
@Override
@@ -105,35 +81,20 @@ private TagRepo tagRepository;
User user = userRepository.findById(dto.getUserDto().getId())
.orElseThrow(() -> new NotFoundException("User", "id", dto.getUserDto().getId()));
Recipe recipe = new Recipe(
dto.getTitle(),
dto.getDescription(),
dto.getPrepTimeMinutes(),
dto.getCookTimeMinutes(),
dto.getServings(),
user,
dto.getStatus()
);
Recipe recipe = new Recipe(dto.getTitle(), dto.getDescription(), dto.getPrepTimeMinutes(),
dto.getCookTimeMinutes(), dto.getServings(), user, dto.getStatus());
for (RecipeIngredientDto riDto : dto.getIngredients()) {
Ingredient ingredient = ingredientRepository.findByName(riDto.getIngredientName())
.orElseGet(() -> new Ingredient(riDto.getIngredientName()));
if (ingredient.getId() == null) {
ingredientRepository.save(ingredient);
}
RecipeIngredient ri = new RecipeIngredient(
recipe,
ingredient,
riDto.getQuantity(),
riDto.getUnit(),
riDto.getNotes()
);
RecipeIngredient ri = new RecipeIngredient(recipe, ingredient, riDto.getQuantity(), riDto.getUnit(),
riDto.getNotes());
recipe.getRecipeIngredients().add(ri);
}
@@ -152,20 +113,9 @@ private TagRepo tagRepository;
}
}
// if (dto.getTags() != null) {
// for (TagDto tagDto : dto.getTags()) {
// Tag tag = new Tag(tagDto.getName());
// tagRepository.save(tag);
// recipe.getTags().add(tag);
// }
// }
for (TagDto tDto : dto.getTags()) {
Tag tag = tagRepository.findByName(tDto.getName())
.orElseGet(() -> new Tag(tDto.getName()));
Tag tag = tagRepository.findByName(tDto.getName()).orElseGet(() -> new Tag(tDto.getName()));
if (tag.getId() == null) {
tagRepository.save(tag);
@@ -194,8 +144,7 @@ private TagRepo tagRepository;
@Override
@Transactional
public RecipeDto getRecipeById(Integer Id) {
return convertToDto(recipeRepository.findById(Id).orElseThrow(() ->
new NotFoundException("Recipe", "id", Id)));
return convertToDto(recipeRepository.findById(Id).orElseThrow(() -> new NotFoundException("Recipe", "id", Id)));
}
@Override
@@ -211,7 +160,6 @@ private TagRepo tagRepository;
existingRecipe.setServings(recipeDto.getServings());
existingRecipe.setStatus(recipeDto.getStatus());
List<RecipeIngredientDto> updatedIngredients = recipeDto.getIngredients();
List<RecipeIngredient> ingredientsToRemove = new ArrayList<>();
@@ -246,13 +194,12 @@ private TagRepo tagRepository;
for (RecipeIngredientDto riDto : updatedIngredients) {
// go through the old list of ingredients until we find a match with updated list
// go through the old list of ingredients until we find a match with updated
// list
RecipeIngredient existingRI = existingRecipe.getRecipeIngredients().stream()
.filter(ri -> ri.getIngredient().getName().equals(riDto.getIngredientName()))
.findFirst()
.filter(ri -> ri.getIngredient().getName().equals(riDto.getIngredientName())).findFirst()
.orElse(null);
// if old ingredient just update parameters
if (existingRI != null) {
@@ -271,25 +218,21 @@ private TagRepo tagRepository;
ingredientRepository.save(ingredient);
}
RecipeIngredient newRI = new RecipeIngredient(
existingRecipe,
ingredient,
riDto.getQuantity(),
riDto.getUnit(),
riDto.getNotes()
);
RecipeIngredient newRI = new RecipeIngredient(existingRecipe, ingredient, riDto.getQuantity(),
riDto.getUnit(), riDto.getNotes());
existingRecipe.getRecipeIngredients().add(newRI);
}
}
if(updatedSteps != null) {
if (updatedSteps != null) {
// find steps that weren't included
for (Step step : existingRecipe.getSteps()) {
boolean existsInUpdatedList = updatedSteps.stream()
.anyMatch(dto -> dto.getStepNumber().equals(step.getStepNumber()));
if (!existsInUpdatedList) stepsToRemove.add(step);
if (!existsInUpdatedList)
stepsToRemove.add(step);
}
// delete those steps
existingRecipe.getSteps().removeAll(stepsToRemove);
@@ -299,9 +242,7 @@ private TagRepo tagRepository;
// find matching step by step number
Step existingStep = existingRecipe.getSteps().stream()
.filter(s -> s.getStepNumber().equals(stepDto.getStepNumber()))
.findFirst()
.orElse(null);
.filter(s -> s.getStepNumber().equals(stepDto.getStepNumber())).findFirst().orElse(null);
// if there's a match update the instruction string
if (existingStep != null) {
@@ -316,55 +257,48 @@ private TagRepo tagRepository;
}
}
//same process as above just with images instead
// same process as above just with images instead
if (updatedImages != null) {
for (Image image : existingRecipe.getImages()) {
boolean existsInUpdatedList = updatedImages.stream()
.anyMatch(dto -> dto.getImageUrl().equals(image.getImageUrl()));
if (!existsInUpdatedList) imagesToRemove.add(image);
if (!existsInUpdatedList)
imagesToRemove.add(image);
}
existingRecipe.getImages().removeAll(imagesToRemove);
for (ImageDto imageDto : updatedImages) {
Image existingImage = existingRecipe.getImages().stream()
.filter(img -> img.getImageUrl().equals(imageDto.getImageUrl()))
.findFirst()
.orElse(null);
.filter(img -> img.getImageUrl().equals(imageDto.getImageUrl())).findFirst().orElse(null);
if (existingImage != null) {
existingImage.setImageUrl(imageDto.getImageUrl());
}
else {
} else {
Image newImage = new Image(existingRecipe, imageDto.getImageUrl());
existingRecipe.getImages().add(newImage);
}
}
}
//same process as above just with tags instead, except for saving the tag
// same process as above just with tags instead, except for saving the tag
// since the relationship for this one was slightly different
if (updatedTags != null) {
for (Tag tag : existingRecipe.getTags()) {
boolean existsInUpdatedList = updatedTags.stream()
.anyMatch(dto -> dto.getName().equals(tag.getName()));
if (!existsInUpdatedList) tagsToRemove.add(tag);
boolean existsInUpdatedList = updatedTags.stream().anyMatch(dto -> dto.getName().equals(tag.getName()));
if (!existsInUpdatedList)
tagsToRemove.add(tag);
}
existingRecipe.getTags().removeAll(tagsToRemove);
for (TagDto tagDto : updatedTags) {
Tag existingTag = existingRecipe.getTags().stream()
.filter(tag -> tag.getName().equals(tagDto.getName()))
.findFirst()
.orElse(null);
.filter(tag -> tag.getName().equals(tagDto.getName())).findFirst().orElse(null);
if (existingTag != null) {
existingTag.setName(tagDto.getName());
}
else {
} else {
Tag newTag = tagRepository.findByName(tagDto.getName())
.orElseGet(() -> tagRepository.save(new Tag(tagDto.getName())));
@@ -378,8 +312,7 @@ private TagRepo tagRepository;
@Override
public void deleteRecipe(Integer Id) {
recipeRepository.findById(Id)
.orElseThrow(() -> new NotFoundException("Recipe", "id", Id));
recipeRepository.findById(Id).orElseThrow(() -> new NotFoundException("Recipe", "id", Id));
recipeRepository.deleteById(Id);
}
@@ -22,7 +22,7 @@ import com.example.demo.service.UserService;
import jakarta.transaction.Transactional;
@Service
public class UserServiceImpl implements UserService{
public class UserServiceImpl implements UserService {
private UserRepo userRepository;
private RecipeRepo recipeRepository;
@@ -34,11 +34,7 @@ public class UserServiceImpl implements UserService{
}
public UserDto convertToDto(User user) {
return new UserDto(
user.getId(),
user.getUsername(),
user.getEmail()
);
return new UserDto(user.getId(), user.getUsername(), user.getEmail());
}
@Override
@@ -61,31 +57,28 @@ public class UserServiceImpl implements UserService{
@Override
public UserDto getUserById(Integer Id) {
return convertToDto(userRepository.findById(Id).orElseThrow(() ->
new NotFoundException("User", "id", Id)));
return convertToDto(userRepository.findById(Id).orElseThrow(() -> new NotFoundException("User", "id", Id)));
}
@Override
@Transactional
public UserDto saveFavorite(Integer userId, Integer recipeId) {
User existingUser = userRepository.findById(userId).orElseThrow(
() -> new NotFoundException("User", "id", userId));
User existingUser = userRepository.findById(userId)
.orElseThrow(() -> new NotFoundException("User", "id", userId));
Recipe existingRecipe = recipeRepository.findById(recipeId).orElseThrow(
() -> new NotFoundException("Recipe", "id", recipeId));
Recipe existingRecipe = recipeRepository.findById(recipeId)
.orElseThrow(() -> new NotFoundException("Recipe", "id", recipeId));
existingUser.getFavRecipes().add(existingRecipe);
userRepository.save(existingUser);
return convertToDto(existingUser);
}
@Override
public UserDto updateUser(User user, Integer Id) {
User existingUser = userRepository.findById(Id).orElseThrow(
() -> new NotFoundException("User", "id", Id));
User existingUser = userRepository.findById(Id).orElseThrow(() -> new NotFoundException("User", "id", Id));
existingUser.setUsername(user.getUsername());
existingUser.setEmail(user.getEmail());
@@ -97,25 +90,22 @@ public class UserServiceImpl implements UserService{
@Override
public void deleteUser(Integer Id) {
userRepository.findById(Id).orElseThrow(
() -> new NotFoundException("User", "id", Id));
userRepository.findById(Id).orElseThrow(() -> new NotFoundException("User", "id", Id));
userRepository.deleteById(Id);
}
@Override
@Transactional
public void deleteFavorite(Integer userId, Integer recipeId) {
User existingUser = userRepository.findById(userId).orElseThrow(
() -> new NotFoundException("User", "id", userId));
User existingUser = userRepository.findById(userId)
.orElseThrow(() -> new NotFoundException("User", "id", userId));
Recipe existingRecipe = recipeRepository.findById(recipeId).orElseThrow(
() -> new NotFoundException("Recipe", "id", recipeId));
Recipe existingRecipe = recipeRepository.findById(recipeId)
.orElseThrow(() -> new NotFoundException("Recipe", "id", recipeId));
userRepository.save(existingUser);
existingUser.getFavRecipes().remove(existingRecipe);
}
}
@@ -9,11 +9,16 @@ import com.example.demo.entity.Recipe;
import com.example.demo.entity.User;
public interface RecipeService {
RecipeDto convertToDto(Recipe recipe) ;
RecipeDto convertToDto(Recipe recipe);
RecipeDto saveRecipe(RecipeDto recipe);
List<RecipeDto> getAllRecipes();
RecipeDto getRecipeById(Integer recipeId);
RecipeDto updateRecipe(RecipeDto recipedto, Integer Id);
void deleteRecipe(Integer Id);
}
@@ -7,11 +7,18 @@ import com.example.demo.entity.User;
public interface UserService {
UserDto convertToDto(User user);
User saveUser(User user);
List<UserDto> getAllUsers();
UserDto getUserById(Integer Id);
UserDto saveFavorite(Integer userId, Integer recipeId);
UserDto updateUser(User user, Integer Id);
void deleteUser(Integer Id);
void deleteFavorite(Integer userId, Integer recipeId);
}