Compare commits
1 Commits
f1b4033c45
...
e441e88061
| Author | SHA1 | Date |
|---|---|---|
|
|
e441e88061 |
|
|
@ -1,47 +0,0 @@
|
||||||
package com.mediamanager.mapper;
|
|
||||||
|
|
||||||
import com.mediamanager.model.TrackHasComposer;
|
|
||||||
import com.mediamanager.protocol.messages.TrackHasComposerMessages;
|
|
||||||
|
|
||||||
public class TrackHasComposerMapper {
|
|
||||||
public static TrackHasComposerMessages.TrackHasComposer toProtobuf(TrackHasComposer entity) {
|
|
||||||
if (entity == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
TrackHasComposerMessages.TrackHasComposer.Builder builder = TrackHasComposerMessages.TrackHasComposer.newBuilder();
|
|
||||||
|
|
||||||
Integer id = entity.getId();
|
|
||||||
if (id != null) {
|
|
||||||
builder.setId(id);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Map Track foreign key
|
|
||||||
if (entity.getTrack() != null && entity.getTrack().getId() != null) {
|
|
||||||
builder.setFkTrackId(entity.getTrack().getId());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Map Composer foreign key
|
|
||||||
if (entity.getComposer() != null && entity.getComposer().getId() != null) {
|
|
||||||
builder.setFkComposerId(entity.getComposer().getId());
|
|
||||||
}
|
|
||||||
|
|
||||||
return builder.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static TrackHasComposer toEntity(TrackHasComposerMessages.TrackHasComposer protobuf) {
|
|
||||||
if (protobuf == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
TrackHasComposer entity = new TrackHasComposer();
|
|
||||||
|
|
||||||
if (protobuf.getId() > 0) {
|
|
||||||
entity.setId(protobuf.getId());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Note: Foreign key relationships (Track, Composer) are handled in the service layer
|
|
||||||
|
|
||||||
return entity;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -1,55 +0,0 @@
|
||||||
package com.mediamanager.model;
|
|
||||||
|
|
||||||
import jakarta.persistence.*;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
@Table(name = "trackhascomposer")
|
|
||||||
public class TrackHasComposer {
|
|
||||||
|
|
||||||
@Id
|
|
||||||
@GeneratedValue(strategy = GenerationType.IDENTITY)
|
|
||||||
private Integer id;
|
|
||||||
|
|
||||||
@ManyToOne(fetch = FetchType.LAZY)
|
|
||||||
@JoinColumn(name = "fk_track_id", nullable = false)
|
|
||||||
private Track track;
|
|
||||||
|
|
||||||
@ManyToOne(fetch = FetchType.LAZY)
|
|
||||||
@JoinColumn(name = "fk_composer_id", nullable = false)
|
|
||||||
private Composer composer;
|
|
||||||
|
|
||||||
public TrackHasComposer() {}
|
|
||||||
|
|
||||||
public Integer getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(Integer id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Track getTrack() {
|
|
||||||
return track;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setTrack(Track track) {
|
|
||||||
this.track = track;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Composer getComposer() {
|
|
||||||
return composer;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setComposer(Composer composer) {
|
|
||||||
this.composer = composer;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "TrackHasComposer{" +
|
|
||||||
"id=" + id +
|
|
||||||
", trackId=" + (track != null ? track.getId() : null) +
|
|
||||||
", composerId=" + (composer != null ? composer.getId() : null) +
|
|
||||||
'}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -1,85 +0,0 @@
|
||||||
package com.mediamanager.repository;
|
|
||||||
|
|
||||||
|
|
||||||
import com.mediamanager.model.TrackHasComposer;
|
|
||||||
import jakarta.persistence.EntityManager;
|
|
||||||
import jakarta.persistence.EntityManagerFactory;
|
|
||||||
import org.apache.logging.log4j.LogManager;
|
|
||||||
import org.apache.logging.log4j.Logger;
|
|
||||||
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Optional;
|
|
||||||
|
|
||||||
public class TrackHasComposerRepository {
|
|
||||||
private static final Logger logger = LogManager.getLogger(TrackHasComposerRepository.class);
|
|
||||||
|
|
||||||
private final EntityManagerFactory entityManagerFactory;
|
|
||||||
|
|
||||||
public TrackHasComposerRepository(EntityManagerFactory entityManagerFactory) {
|
|
||||||
this.entityManagerFactory = entityManagerFactory;
|
|
||||||
}
|
|
||||||
|
|
||||||
public TrackHasComposer save(TrackHasComposer trackHasComposer) {
|
|
||||||
logger.debug("Saving TrackHasComposer: {}", trackHasComposer);
|
|
||||||
EntityManager em = entityManagerFactory.createEntityManager();
|
|
||||||
em.getTransaction().begin();
|
|
||||||
try {
|
|
||||||
em.persist(trackHasComposer);
|
|
||||||
em.getTransaction().commit();
|
|
||||||
logger.debug("TrackHasComposer has been saved successfully");
|
|
||||||
return trackHasComposer;
|
|
||||||
} catch (Exception e) {
|
|
||||||
em.getTransaction().rollback();
|
|
||||||
logger.error("Error while saving TrackHasComposer: {}", e.getMessage());
|
|
||||||
throw e;
|
|
||||||
} finally {
|
|
||||||
if (em.isOpen()) em.close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<TrackHasComposer> findAll() {
|
|
||||||
logger.debug("Finding All TrackHasComposer");
|
|
||||||
EntityManager em = entityManagerFactory.createEntityManager();
|
|
||||||
try{
|
|
||||||
return em.createQuery("select t from TrackHasComposer t", TrackHasComposer.class).getResultList();
|
|
||||||
}finally {
|
|
||||||
if (em.isOpen()) em.close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public Optional<TrackHasComposer> findById(Integer id) {
|
|
||||||
logger.debug("Finding TrackHasComposer with id: {}", id);
|
|
||||||
EntityManager em = entityManagerFactory.createEntityManager();
|
|
||||||
try{
|
|
||||||
TrackHasComposer trackHasComposer = em.find(TrackHasComposer.class, id);
|
|
||||||
return Optional.ofNullable(trackHasComposer);
|
|
||||||
}finally {
|
|
||||||
if (em.isOpen()) em.close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean deleteById(Integer id){
|
|
||||||
logger.debug("Deleting TrackHasComposer with id: {}", id);
|
|
||||||
EntityManager em = entityManagerFactory.createEntityManager();
|
|
||||||
em.getTransaction().begin();
|
|
||||||
try{
|
|
||||||
TrackHasComposer trackHasComposer = em.find(TrackHasComposer.class, id);
|
|
||||||
if (trackHasComposer == null) {
|
|
||||||
em.getTransaction().rollback();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
em.remove(trackHasComposer);
|
|
||||||
em.getTransaction().commit();
|
|
||||||
logger.debug("TrackHasComposer has been deleted successfully");
|
|
||||||
return true;
|
|
||||||
} catch (Exception e) {
|
|
||||||
em.getTransaction().rollback();
|
|
||||||
logger.error("Error while deleting TrackHasComposer: {}", e.getMessage());
|
|
||||||
throw e;
|
|
||||||
} finally {
|
|
||||||
if (em.isOpen()) em.close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
@ -14,7 +14,6 @@ import com.mediamanager.service.bitrate.BitRateService;
|
||||||
import com.mediamanager.service.composer.ComposerService;
|
import com.mediamanager.service.composer.ComposerService;
|
||||||
import com.mediamanager.service.trackhasgenre.TrackHasGenreService;
|
import com.mediamanager.service.trackhasgenre.TrackHasGenreService;
|
||||||
import com.mediamanager.service.trackhasartist.TrackHasArtistService;
|
import com.mediamanager.service.trackhasartist.TrackHasArtistService;
|
||||||
import com.mediamanager.service.trackhascomposer.TrackHasComposerService;
|
|
||||||
|
|
||||||
import com.mediamanager.repository.GenreRepository;
|
import com.mediamanager.repository.GenreRepository;
|
||||||
import com.mediamanager.service.artist.ArtistService;
|
import com.mediamanager.service.artist.ArtistService;
|
||||||
|
|
@ -123,10 +122,6 @@ public class DelegateActionManager {
|
||||||
TrackHasArtistService trackHasArtistService = new TrackHasArtistService(trackHasArtistRepository, trackRepository, artistRepository);
|
TrackHasArtistService trackHasArtistService = new TrackHasArtistService(trackHasArtistRepository, trackRepository, artistRepository);
|
||||||
serviceLocator.register(TrackHasArtistService.class, trackHasArtistService);
|
serviceLocator.register(TrackHasArtistService.class, trackHasArtistService);
|
||||||
|
|
||||||
TrackHasComposerRepository trackHasComposerRepository = new TrackHasComposerRepository(entityManagerFactory);
|
|
||||||
TrackHasComposerService trackHasComposerService = new TrackHasComposerService(trackHasComposerRepository, trackRepository, composerRepository);
|
|
||||||
serviceLocator.register(TrackHasComposerService.class, trackHasComposerService);
|
|
||||||
|
|
||||||
serviceLocator.logRegisteredServices();
|
serviceLocator.logRegisteredServices();
|
||||||
|
|
||||||
logger.info("Services initialized successfully");
|
logger.info("Services initialized successfully");
|
||||||
|
|
|
||||||
|
|
@ -1,54 +0,0 @@
|
||||||
package com.mediamanager.service.delegate.handler.trackhascomposer;
|
|
||||||
|
|
||||||
import com.google.protobuf.ByteString;
|
|
||||||
import com.google.protobuf.InvalidProtocolBufferException;
|
|
||||||
import com.mediamanager.mapper.TrackHasComposerMapper;
|
|
||||||
import com.mediamanager.model.TrackHasComposer;
|
|
||||||
import com.mediamanager.protocol.TransportProtocol;
|
|
||||||
import com.mediamanager.protocol.messages.TrackHasComposerMessages;
|
|
||||||
import com.mediamanager.service.delegate.ActionHandler;
|
|
||||||
import com.mediamanager.service.delegate.annotation.Action;
|
|
||||||
import com.mediamanager.service.trackhascomposer.TrackHasComposerService;
|
|
||||||
import org.apache.logging.log4j.LogManager;
|
|
||||||
import org.apache.logging.log4j.Logger;
|
|
||||||
|
|
||||||
@Action("trackhascomposer.create")
|
|
||||||
public class CreateTrackHasComposerHandler implements ActionHandler {
|
|
||||||
private static final Logger logger = LogManager.getLogger(CreateTrackHasComposerHandler.class);
|
|
||||||
private final TrackHasComposerService trackHasComposerService;
|
|
||||||
|
|
||||||
public CreateTrackHasComposerHandler(TrackHasComposerService trackHasComposerService) {
|
|
||||||
this.trackHasComposerService = trackHasComposerService;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public TransportProtocol.Response.Builder handle(ByteString requestPayload) throws InvalidProtocolBufferException {
|
|
||||||
try{
|
|
||||||
TrackHasComposerMessages.CreateTrackHasComposerRequest createRequest =
|
|
||||||
TrackHasComposerMessages.CreateTrackHasComposerRequest.parseFrom(requestPayload);
|
|
||||||
|
|
||||||
TrackHasComposer trackHasComposer = trackHasComposerService.createTrackHasComposer(
|
|
||||||
createRequest.getFkTrackId() > 0 ? createRequest.getFkTrackId() : null,
|
|
||||||
createRequest.getFkComposerId() > 0 ? createRequest.getFkComposerId() : null
|
|
||||||
);
|
|
||||||
|
|
||||||
TrackHasComposerMessages.TrackHasComposer trackHasComposerProto = TrackHasComposerMapper.toProtobuf(trackHasComposer);
|
|
||||||
TrackHasComposerMessages.CreateTrackHasComposerResponse createTrackHasComposerResponse = TrackHasComposerMessages.CreateTrackHasComposerResponse.newBuilder()
|
|
||||||
.setTrackhascomposer(trackHasComposerProto)
|
|
||||||
.build();
|
|
||||||
return TransportProtocol.Response.newBuilder()
|
|
||||||
.setPayload(createTrackHasComposerResponse.toByteString());
|
|
||||||
} catch (IllegalArgumentException e) {
|
|
||||||
logger.error("Validation error", e);
|
|
||||||
return TransportProtocol.Response.newBuilder()
|
|
||||||
.setStatusCode(400)
|
|
||||||
.setPayload(ByteString.copyFromUtf8("Validation error: " + e.getMessage()));
|
|
||||||
|
|
||||||
} catch (Exception e) {
|
|
||||||
logger.error("Error creating track has composer", e);
|
|
||||||
return TransportProtocol.Response.newBuilder()
|
|
||||||
.setStatusCode(500)
|
|
||||||
.setPayload(ByteString.copyFromUtf8("Error: " + e.getMessage()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -1,62 +0,0 @@
|
||||||
package com.mediamanager.service.delegate.handler.trackhascomposer;
|
|
||||||
|
|
||||||
import com.google.protobuf.ByteString;
|
|
||||||
import com.google.protobuf.InvalidProtocolBufferException;
|
|
||||||
import com.mediamanager.protocol.TransportProtocol;
|
|
||||||
import com.mediamanager.protocol.messages.TrackHasComposerMessages;
|
|
||||||
import com.mediamanager.service.delegate.ActionHandler;
|
|
||||||
import com.mediamanager.service.delegate.annotation.Action;
|
|
||||||
import com.mediamanager.service.trackhascomposer.TrackHasComposerService;
|
|
||||||
import org.apache.logging.log4j.LogManager;
|
|
||||||
import org.apache.logging.log4j.Logger;
|
|
||||||
|
|
||||||
@Action("trackhascomposer.delete")
|
|
||||||
public class DeleteTrackHasComposerHandler implements ActionHandler {
|
|
||||||
private static final Logger logger = LogManager.getLogger(DeleteTrackHasComposerHandler.class);
|
|
||||||
|
|
||||||
private final TrackHasComposerService trackHasComposerService;
|
|
||||||
|
|
||||||
public DeleteTrackHasComposerHandler(TrackHasComposerService trackHasComposerService) {
|
|
||||||
this.trackHasComposerService = trackHasComposerService;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public TransportProtocol.Response.Builder handle(ByteString requestPayload)
|
|
||||||
throws InvalidProtocolBufferException {
|
|
||||||
|
|
||||||
try {
|
|
||||||
TrackHasComposerMessages.DeleteTrackHasComposerRequest deleteRequest =
|
|
||||||
TrackHasComposerMessages.DeleteTrackHasComposerRequest.parseFrom(requestPayload);
|
|
||||||
int id = deleteRequest.getId();
|
|
||||||
boolean success = trackHasComposerService.deleteTrackHasComposer(id);
|
|
||||||
TrackHasComposerMessages.DeleteTrackHasComposerResponse deleteResponse;
|
|
||||||
if (success) {
|
|
||||||
deleteResponse = TrackHasComposerMessages.DeleteTrackHasComposerResponse.newBuilder()
|
|
||||||
.setSuccess(true)
|
|
||||||
.setMessage("Track has composer deleted successfully")
|
|
||||||
.build();
|
|
||||||
return TransportProtocol.Response.newBuilder()
|
|
||||||
.setPayload(deleteResponse.toByteString());
|
|
||||||
} else {
|
|
||||||
deleteResponse = TrackHasComposerMessages.DeleteTrackHasComposerResponse.newBuilder()
|
|
||||||
.setSuccess(false)
|
|
||||||
.setMessage("Track has composer not found")
|
|
||||||
.build();
|
|
||||||
|
|
||||||
return TransportProtocol.Response.newBuilder()
|
|
||||||
.setStatusCode(404)
|
|
||||||
.setPayload(deleteResponse.toByteString());
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
logger.error("Error deleting track has composer", e);
|
|
||||||
TrackHasComposerMessages.DeleteTrackHasComposerResponse deleteResponse =
|
|
||||||
TrackHasComposerMessages.DeleteTrackHasComposerResponse.newBuilder()
|
|
||||||
.setSuccess(false)
|
|
||||||
.setMessage("Error: " + e.getMessage())
|
|
||||||
.build();
|
|
||||||
return TransportProtocol.Response.newBuilder()
|
|
||||||
.setStatusCode(500)
|
|
||||||
.setPayload(deleteResponse.toByteString());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -1,56 +0,0 @@
|
||||||
package com.mediamanager.service.delegate.handler.trackhascomposer;
|
|
||||||
|
|
||||||
import com.google.protobuf.ByteString;
|
|
||||||
import com.google.protobuf.InvalidProtocolBufferException;
|
|
||||||
import com.mediamanager.mapper.TrackHasComposerMapper;
|
|
||||||
import com.mediamanager.model.TrackHasComposer;
|
|
||||||
import com.mediamanager.protocol.TransportProtocol;
|
|
||||||
import com.mediamanager.protocol.messages.TrackHasComposerMessages;
|
|
||||||
import com.mediamanager.service.delegate.ActionHandler;
|
|
||||||
import com.mediamanager.service.delegate.annotation.Action;
|
|
||||||
import com.mediamanager.service.trackhascomposer.TrackHasComposerService;
|
|
||||||
import org.apache.logging.log4j.LogManager;
|
|
||||||
import org.apache.logging.log4j.Logger;
|
|
||||||
|
|
||||||
import java.util.Optional;
|
|
||||||
|
|
||||||
@Action(value = "trackhascomposer.getById")
|
|
||||||
public class GetTrackHasComposerByIdHandler implements ActionHandler {
|
|
||||||
private static final Logger logger = LogManager.getLogger(GetTrackHasComposerByIdHandler.class);
|
|
||||||
private final TrackHasComposerService trackHasComposerService;
|
|
||||||
|
|
||||||
public GetTrackHasComposerByIdHandler(TrackHasComposerService trackHasComposerService) {
|
|
||||||
this.trackHasComposerService = trackHasComposerService;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public TransportProtocol.Response.Builder handle(ByteString requestPayload)
|
|
||||||
throws InvalidProtocolBufferException{
|
|
||||||
|
|
||||||
try{
|
|
||||||
TrackHasComposerMessages.GetTrackHasComposerByIdRequest getByIdRequest =
|
|
||||||
TrackHasComposerMessages.GetTrackHasComposerByIdRequest.parseFrom(requestPayload);
|
|
||||||
int id = getByIdRequest.getId();
|
|
||||||
|
|
||||||
Optional<TrackHasComposer> trackHasComposerOpt = trackHasComposerService.getTrackHasComposerById(id);
|
|
||||||
|
|
||||||
if (trackHasComposerOpt.isEmpty()){
|
|
||||||
logger.warn("TrackHasComposer not found with ID: {}", id);
|
|
||||||
return TransportProtocol.Response.newBuilder()
|
|
||||||
.setStatusCode(404)
|
|
||||||
.setPayload(ByteString.copyFromUtf8("TrackHasComposer not found"));
|
|
||||||
}
|
|
||||||
TrackHasComposerMessages.TrackHasComposer trackHasComposerProto = TrackHasComposerMapper.toProtobuf(trackHasComposerOpt.get());
|
|
||||||
TrackHasComposerMessages.GetTrackHasComposerByIdResponse getByIdResponse = TrackHasComposerMessages.GetTrackHasComposerByIdResponse.newBuilder()
|
|
||||||
.setTrackhascomposer(trackHasComposerProto)
|
|
||||||
.build();
|
|
||||||
return TransportProtocol.Response.newBuilder()
|
|
||||||
.setPayload(getByIdResponse.toByteString());
|
|
||||||
} catch (Exception e) {
|
|
||||||
logger.error("Error getting track has composer by ID", e);
|
|
||||||
return TransportProtocol.Response.newBuilder()
|
|
||||||
.setStatusCode(500)
|
|
||||||
.setPayload(ByteString.copyFromUtf8("Error: "+ e.getMessage()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -1,48 +0,0 @@
|
||||||
package com.mediamanager.service.delegate.handler.trackhascomposer;
|
|
||||||
|
|
||||||
import com.google.protobuf.ByteString;
|
|
||||||
import com.google.protobuf.InvalidProtocolBufferException;
|
|
||||||
import com.mediamanager.mapper.TrackHasComposerMapper;
|
|
||||||
import com.mediamanager.model.TrackHasComposer;
|
|
||||||
import com.mediamanager.protocol.TransportProtocol;
|
|
||||||
import com.mediamanager.protocol.messages.TrackHasComposerMessages;
|
|
||||||
import com.mediamanager.service.delegate.ActionHandler;
|
|
||||||
import com.mediamanager.service.delegate.annotation.Action;
|
|
||||||
import com.mediamanager.service.trackhascomposer.TrackHasComposerService;
|
|
||||||
import org.apache.logging.log4j.LogManager;
|
|
||||||
import org.apache.logging.log4j.Logger;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
|
|
||||||
@Action("trackhascomposer.getAll")
|
|
||||||
public class GetTrackHasComposerHandler implements ActionHandler {
|
|
||||||
private static final Logger logger = LogManager.getLogger(GetTrackHasComposerHandler.class);
|
|
||||||
|
|
||||||
private final TrackHasComposerService trackHasComposerService;
|
|
||||||
|
|
||||||
public GetTrackHasComposerHandler(TrackHasComposerService trackHasComposerService){this.trackHasComposerService = trackHasComposerService;}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public TransportProtocol.Response.Builder handle(ByteString requestPayload) throws InvalidProtocolBufferException {
|
|
||||||
try{
|
|
||||||
List<TrackHasComposer> trackHasComposers = trackHasComposerService.getAllTrackHasComposers();
|
|
||||||
TrackHasComposerMessages.GetTrackHasComposersResponse.Builder responseBuilder = TrackHasComposerMessages.GetTrackHasComposersResponse.newBuilder();
|
|
||||||
|
|
||||||
for (TrackHasComposer trackHasComposer : trackHasComposers) {
|
|
||||||
TrackHasComposerMessages.TrackHasComposer trackHasComposerProto = TrackHasComposerMapper.toProtobuf(trackHasComposer);
|
|
||||||
responseBuilder.addTrackhascomposer(trackHasComposerProto);
|
|
||||||
}
|
|
||||||
TrackHasComposerMessages.GetTrackHasComposersResponse getTrackHasComposersResponse = responseBuilder.build();
|
|
||||||
|
|
||||||
return TransportProtocol.Response.newBuilder()
|
|
||||||
.setPayload(getTrackHasComposersResponse.toByteString());
|
|
||||||
|
|
||||||
}catch (Exception e){
|
|
||||||
logger.error("Error getting track has composers", e);
|
|
||||||
return TransportProtocol.Response.newBuilder()
|
|
||||||
.setStatusCode(500)
|
|
||||||
.setPayload(ByteString.copyFromUtf8("Error: " + e.getMessage()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -1,77 +0,0 @@
|
||||||
package com.mediamanager.service.trackhascomposer;
|
|
||||||
|
|
||||||
import com.mediamanager.model.Track;
|
|
||||||
import com.mediamanager.model.TrackHasComposer;
|
|
||||||
import com.mediamanager.model.Composer;
|
|
||||||
import com.mediamanager.repository.TrackHasComposerRepository;
|
|
||||||
import com.mediamanager.repository.TrackRepository;
|
|
||||||
import com.mediamanager.repository.ComposerRepository;
|
|
||||||
import org.apache.logging.log4j.LogManager;
|
|
||||||
import org.apache.logging.log4j.Logger;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Optional;
|
|
||||||
|
|
||||||
public class TrackHasComposerService {
|
|
||||||
private static final Logger logger = LogManager.getLogger(TrackHasComposerService.class);
|
|
||||||
private final TrackHasComposerRepository repository;
|
|
||||||
private final TrackRepository trackRepository;
|
|
||||||
private final ComposerRepository composerRepository;
|
|
||||||
|
|
||||||
public TrackHasComposerService(TrackHasComposerRepository repository, TrackRepository trackRepository, ComposerRepository composerRepository) {
|
|
||||||
this.repository = repository;
|
|
||||||
this.trackRepository = trackRepository;
|
|
||||||
this.composerRepository = composerRepository;
|
|
||||||
}
|
|
||||||
|
|
||||||
public TrackHasComposer createTrackHasComposer(Integer trackId, Integer composerId) {
|
|
||||||
logger.debug("Creating track has composer relationship - trackId:{}, composerId:{}", trackId, composerId);
|
|
||||||
|
|
||||||
if (trackId == null || trackId <= 0) {
|
|
||||||
throw new IllegalArgumentException("Track ID cannot be null or invalid");
|
|
||||||
}
|
|
||||||
if (composerId == null || composerId <= 0) {
|
|
||||||
throw new IllegalArgumentException("Composer ID cannot be null or invalid");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Verify Track exists
|
|
||||||
Optional<Track> track = trackRepository.findById(trackId);
|
|
||||||
if (track.isEmpty()) {
|
|
||||||
throw new IllegalArgumentException("Track not found with id: " + trackId);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Verify Composer exists
|
|
||||||
Optional<Composer> composer = composerRepository.findById(composerId);
|
|
||||||
if (composer.isEmpty()) {
|
|
||||||
throw new IllegalArgumentException("Composer not found with id: " + composerId);
|
|
||||||
}
|
|
||||||
|
|
||||||
TrackHasComposer trackHasComposer = new TrackHasComposer();
|
|
||||||
trackHasComposer.setTrack(track.get());
|
|
||||||
trackHasComposer.setComposer(composer.get());
|
|
||||||
|
|
||||||
return repository.save(trackHasComposer);
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<TrackHasComposer> getAllTrackHasComposers() {
|
|
||||||
logger.info("Getting all track has composer relationships");
|
|
||||||
return repository.findAll();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Optional<TrackHasComposer> getTrackHasComposerById(Integer id) {
|
|
||||||
if (id == null) {
|
|
||||||
throw new IllegalArgumentException("ID cannot be null");
|
|
||||||
}
|
|
||||||
logger.info("Getting track has composer by id:{}", id);
|
|
||||||
return repository.findById(id);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean deleteTrackHasComposer(Integer id) {
|
|
||||||
if (id == null) {
|
|
||||||
throw new IllegalArgumentException("Track has composer id cannot be null");
|
|
||||||
}
|
|
||||||
logger.info("Deleting track has composer:{}", id);
|
|
||||||
return repository.deleteById(id);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
@ -1,46 +0,0 @@
|
||||||
syntax = "proto3";
|
|
||||||
|
|
||||||
option java_package = "com.mediamanager.protocol.messages";
|
|
||||||
option java_outer_classname = "TrackHasComposerMessages";
|
|
||||||
|
|
||||||
package mediamanager.messages;
|
|
||||||
|
|
||||||
message TrackHasComposer{
|
|
||||||
int32 id = 1;
|
|
||||||
int32 fk_track_id = 2;
|
|
||||||
int32 fk_composer_id =3;
|
|
||||||
}
|
|
||||||
|
|
||||||
message CreateTrackHasComposerRequest {
|
|
||||||
int32 fk_track_id = 1;
|
|
||||||
int32 fk_composer_id = 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
message CreateTrackHasComposerResponse {
|
|
||||||
TrackHasComposer trackhascomposer = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
message GetTrackHasComposersRequest {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
message GetTrackHasComposersResponse {
|
|
||||||
repeated TrackHasComposer trackhascomposer = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
message GetTrackHasComposerByIdRequest {
|
|
||||||
int32 id = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
message GetTrackHasComposerByIdResponse {
|
|
||||||
TrackHasComposer trackhascomposer = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
message DeleteTrackHasComposerRequest {
|
|
||||||
int32 id = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
message DeleteTrackHasComposerResponse {
|
|
||||||
bool success = 1;
|
|
||||||
string message = 2;
|
|
||||||
}
|
|
||||||
Loading…
Reference in New Issue