Skip to content

Commit

Permalink
Merge branch 'develop' into feature-2805/convert-skills-data-structure
Browse files Browse the repository at this point in the history
  • Loading branch information
ocielliottc committed Jan 8, 2025
2 parents 8b3188a + 244fc81 commit ef35363
Show file tree
Hide file tree
Showing 24 changed files with 1,406 additions and 2,614 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,177 @@
package com.objectcomputing.checkins.services.file;

import com.objectcomputing.checkins.services.checkindocument.CheckinDocument;
import com.objectcomputing.checkins.services.checkindocument.CheckinDocumentServices;
import com.objectcomputing.checkins.services.checkins.CheckIn;
import com.objectcomputing.checkins.services.checkins.CheckInServices;
import com.objectcomputing.checkins.services.memberprofile.MemberProfile;
import com.objectcomputing.checkins.services.memberprofile.MemberProfileServices;
import com.objectcomputing.checkins.services.memberprofile.MemberProfileUtils;
import com.objectcomputing.checkins.services.memberprofile.currentuser.CurrentUserServices;

import io.micronaut.core.annotation.Nullable;
import io.micronaut.http.multipart.CompletedFileUpload;

import jakarta.inject.Singleton;
import jakarta.validation.constraints.NotNull;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Collections;
import java.util.HashSet;
import java.util.Set;
import java.util.UUID;
import java.util.function.Function;

import static com.objectcomputing.checkins.services.validate.PermissionsValidation.NOT_AUTHORIZED_MSG;

@Singleton
abstract public class FileServicesBaseImpl implements FileServices {
private static final Logger LOG = LoggerFactory.getLogger(FileServicesBaseImpl.class);

protected final CheckInServices checkInServices;
protected final CheckinDocumentServices checkinDocumentServices;
protected final MemberProfileServices memberProfileServices;
protected final CurrentUserServices currentUserServices;

public FileServicesBaseImpl(CheckInServices checkInServices,
CheckinDocumentServices checkinDocumentServices,
MemberProfileServices memberProfileServices,
CurrentUserServices currentUserServices) {
this.checkInServices = checkInServices;
this.checkinDocumentServices = checkinDocumentServices;
this.memberProfileServices = memberProfileServices;
this.currentUserServices = currentUserServices;
}

abstract protected void getCheckinDocuments(
Set<FileInfoDTO> result, Set<CheckinDocument> checkinDocuments) throws IOException;
abstract protected void downloadSingleFile(
String docId, FileOutputStream myWriter) throws IOException;
abstract protected FileInfoDTO uploadSingleFile(
CompletedFileUpload file, String directoryName,
Function<String, CheckinDocument> consumer) throws IOException;
abstract protected void deleteSingleFile(String docId) throws IOException;

@Override
public Set<FileInfoDTO> findFiles(@Nullable UUID checkInID) {
boolean isAdmin = currentUserServices.isAdmin();
validate(checkInID == null && !isAdmin, NOT_AUTHORIZED_MSG);

try {
Set<FileInfoDTO> result = new HashSet<>();
if (checkInID == null && isAdmin) {
getCheckinDocuments(result, Collections.emptySet());
} else if (checkInID != null) {
validate(!checkInServices.accessGranted(checkInID, currentUserServices.getCurrentUser().getId()),
"You are not authorized to perform this operation");

// If there aren't any documents, do not call
// getCheckinDocument. It assumes that an empty set means
// that it should attempt to get all documents. And, in this
// case, we just want an empty result set.
Set<CheckinDocument> checkinDocuments = checkinDocumentServices.read(checkInID);
if (!checkinDocuments.isEmpty()) {
getCheckinDocuments(result, checkinDocuments);
}
}

return result;
} catch (IOException e) {
LOG.error("Error occurred while retrieving files.", e);
throw new FileRetrievalException(e.getMessage());
}
}

@Override
public java.io.File downloadFiles(@NotNull String uploadDocId) {
MemberProfile currentUser = currentUserServices.getCurrentUser();
boolean isAdmin = currentUserServices.isAdmin();

CheckinDocument cd = checkinDocumentServices.getFindByUploadDocId(uploadDocId);
validate(cd == null, String.format("Unable to find record with id %s", uploadDocId));

CheckIn associatedCheckin = checkInServices.read(cd.getCheckinsId());

if(!isAdmin) {
validate((!currentUser.getId().equals(associatedCheckin.getTeamMemberId()) && !currentUser.getId().equals(associatedCheckin.getPdlId())), NOT_AUTHORIZED_MSG);
}
try {
java.io.File file = java.io.File.createTempFile("tmp", ".txt");
file.deleteOnExit();
try(
FileOutputStream myWriter = new FileOutputStream(file)
) {
downloadSingleFile(uploadDocId, myWriter);
return file;
} catch (IOException e) {
LOG.error("Error occurred while retrieving files.", e);
throw new FileRetrievalException(e.getMessage());
}
} catch(IOException e) {
LOG.error("Error occurred while attempting to create a temporary file.", e);
throw new FileRetrievalException(e.getMessage());
}
}

@Override
public FileInfoDTO uploadFile(@NotNull UUID checkInID, @NotNull CompletedFileUpload file) {
MemberProfile currentUser = currentUserServices.getCurrentUser();
boolean isAdmin = currentUserServices.isAdmin();
validate((file.getFilename() == null || file.getFilename().equals("")), "Please select a valid file before uploading.");

CheckIn checkIn = checkInServices.read(checkInID);
validate(checkIn == null, "Unable to find checkin record with id %s", checkInID);
if(!isAdmin) {
validate((!currentUser.getId().equals(checkIn.getTeamMemberId()) && !currentUser.getId().equals(checkIn.getPdlId())), "You are not authorized to perform this operation");
validate(checkIn.isCompleted(), NOT_AUTHORIZED_MSG);
}

// create folder for each team member
final String directoryName = MemberProfileUtils.getFullName(memberProfileServices.getById(checkIn.getTeamMemberId()));

try {
return uploadSingleFile(file, directoryName,
(fileId) -> {
//create record in checkin-document service
CheckinDocument cd = new CheckinDocument(checkInID, fileId);
checkinDocumentServices.save(cd);
return cd;
});
} catch (IOException e) {
LOG.error("Unexpected error processing file upload.", e);
throw new FileRetrievalException(e.getMessage());
}
}

@Override
public boolean deleteFile(@NotNull String uploadDocId) {
MemberProfile currentUser = currentUserServices.getCurrentUser();
boolean isAdmin = currentUserServices.isAdmin();

CheckinDocument cd = checkinDocumentServices.getFindByUploadDocId(uploadDocId);
validate(cd == null, String.format("Unable to find record with id %s", uploadDocId));

CheckIn associatedCheckin = checkInServices.read(cd.getCheckinsId());
if(!isAdmin) {
validate((!currentUser.getId().equals(associatedCheckin.getTeamMemberId()) && !currentUser.getId().equals(associatedCheckin.getPdlId())), NOT_AUTHORIZED_MSG);
}

try {
deleteSingleFile(uploadDocId);
checkinDocumentServices.deleteByUploadDocId(uploadDocId);
return true;
} catch (IOException e) {
LOG.error("Error occurred while deleting files.", e);
throw new FileRetrievalException(e.getMessage());
}
}

protected void validate(boolean isError, String message, Object... args) {
if(isError) {
throw new FileRetrievalException(String.format(message, args));
}
}
}
Loading

0 comments on commit ef35363

Please sign in to comment.