Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
56 changes: 0 additions & 56 deletions src/main/java/com/provedcode/kudos/KudosService.java

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package com.provedcode.kudos;
package com.provedcode.kudos.controller;

import com.provedcode.kudos.service.KudosService;
import com.provedcode.kudos.model.response.KudosAmount;
import lombok.AllArgsConstructor;
import org.springframework.security.access.prepost.PreAuthorize;
Expand All @@ -12,7 +13,6 @@
public class KudosController {
KudosService kudosService;

@PreAuthorize("hasRole('TALENT')")
@GetMapping("/proofs/{proof-id}/kudos")
KudosAmount getKudosProof(@PathVariable("proof-id") long id) {
return kudosService.getAmountKudosProof(id);
Expand All @@ -23,4 +23,10 @@ KudosAmount getKudosProof(@PathVariable("proof-id") long id) {
void addKudosToProof(@PathVariable("proof-id") long id, Authentication authentication) {
kudosService.addKudosToProof(id, authentication);
}

@PreAuthorize("hasRole('TALENT')")
@DeleteMapping("/proofs/{proof-id}/kudos")
void deleteKudosFromProof(@PathVariable("proof-id") long id, Authentication authentication) {
kudosService.deleteKudosFromProof(id, authentication);
}
}
4 changes: 3 additions & 1 deletion src/main/java/com/provedcode/kudos/model/entity/Kudos.java
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@
import jakarta.persistence.*;
import lombok.*;

import java.util.List;

@Getter
@Setter
@Entity
Expand All @@ -20,7 +22,7 @@ public class Kudos {
@ManyToOne(cascade = CascadeType.ALL)
@JoinColumn(name = "talent_id")
private Talent talent;
@OneToOne(cascade = CascadeType.ALL, orphanRemoval = true)
@ManyToOne
@JoinColumn(name = "proof_id")
private TalentProof proof;
}
Original file line number Diff line number Diff line change
@@ -1,13 +1,12 @@
package com.provedcode.kudos;
package com.provedcode.kudos.repository;

import com.provedcode.kudos.model.entity.Kudos;
import com.provedcode.talent.model.entity.Talent;
import com.provedcode.talent.model.entity.TalentProof;
import org.springframework.data.jpa.repository.JpaRepository;

public interface KudosRepository extends JpaRepository<Kudos, Long> {
long countByProof_Id(Long id);

boolean existsByTalent(Talent talent);


}
89 changes: 89 additions & 0 deletions src/main/java/com/provedcode/kudos/service/KudosService.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
package com.provedcode.kudos.service;

import com.provedcode.kudos.model.entity.Kudos;
import com.provedcode.kudos.model.response.KudosAmount;
import com.provedcode.kudos.repository.KudosRepository;
import com.provedcode.talent.model.ProofStatus;
import com.provedcode.talent.model.entity.Talent;
import com.provedcode.talent.model.entity.TalentProof;
import com.provedcode.talent.repo.TalentProofRepository;
import com.provedcode.talent.repo.TalentRepository;
import com.provedcode.user.model.entity.UserInfo;
import com.provedcode.user.repo.UserInfoRepository;
import lombok.AllArgsConstructor;
import org.springframework.http.HttpStatus;
import org.springframework.security.core.Authentication;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.server.ResponseStatusException;

import java.util.List;

import static org.springframework.http.HttpStatus.*;

@Service
@AllArgsConstructor
@Transactional
public class KudosService {
KudosRepository kudosRepository;
TalentRepository talentRepository;
TalentProofRepository talentProofRepository;
UserInfoRepository userInfoRepository;

@Transactional(readOnly = true)
public KudosAmount getAmountKudosProof(long id) {
TalentProof talentProof = talentProofRepository.findById(id)
.orElseThrow(() -> new ResponseStatusException(NOT_FOUND, "proof with id = %s not found".formatted(id)));

if (!talentProof.getStatus().equals(ProofStatus.PUBLISHED)) {
throw new ResponseStatusException(FORBIDDEN);
}

long count = kudosRepository.countByProof_Id(id);
return new KudosAmount(count);
}

public void addKudosToProof(long id, Authentication authentication) {
UserInfo userInfo = userInfoRepository.findByLogin(authentication.getName())
.orElseThrow(() -> new ResponseStatusException(NOT_FOUND, "Talent with id = %s not found".formatted(id)));

Talent talent = userInfo.getTalent();

TalentProof talentProof = talentProofRepository.findById(id)
.orElseThrow(() -> new ResponseStatusException(NOT_FOUND, "Proof with id = %s not found".formatted(id)));

if (talent.getId().equals(talentProof.getTalent().getId())) {
throw new ResponseStatusException(FORBIDDEN, "Talent can’t give `kudos` to himself");
}
if (kudosRepository.existsByTalent(talent)) {
throw new ResponseStatusException(CONFLICT, "Talent can give only one `kudos` for one proof");
}
if (!talentProof.getStatus().equals(ProofStatus.PUBLISHED)) {
throw new ResponseStatusException(FORBIDDEN);
}

kudosRepository.save(Kudos.builder()
.proof(talentProof)
.talent(talent)
.build());
}

public void deleteKudosFromProof(long id, Authentication authentication) {
UserInfo userInfo = userInfoRepository.findByLogin(authentication.getName())
.orElseThrow(() -> new ResponseStatusException(NOT_FOUND, "Talent with id = %s not found".formatted(id)));
Talent talent = userInfo.getTalent();

TalentProof talentProof = talentProofRepository.findById(id)
.orElseThrow(() -> new ResponseStatusException(NOT_FOUND, "Proof with id = %s not found".formatted(id)));

if (!kudosRepository.existsByTalent(talent)) {
throw new ResponseStatusException(CONFLICT, "kudos don`t exist");
}

Kudos kudos = talent.getCudoses().stream().filter(i -> i.getProof().getId().equals(id)).findFirst().orElseThrow();
talentProof.getKudos().remove(kudos);
talent.getCudoses().remove(kudos);

talentRepository.save(talent);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
import org.hibernate.validator.constraints.URL;

import java.time.LocalDateTime;
import java.util.List;

@Accessors(chain = true)
@NoArgsConstructor
Expand Down Expand Up @@ -38,6 +39,6 @@ public class TalentProof {
@Column(length = 20)
private ProofStatus status;
private LocalDateTime created;
@OneToOne(mappedBy = "proof", cascade = CascadeType.ALL, orphanRemoval = true)
private Kudos kudos;
@OneToMany(fetch = FetchType.EAGER, mappedBy = "proof", cascade = CascadeType.ALL, orphanRemoval = true)
private List<Kudos> kudos;
}