Commit 3c98aa18 authored by Nicola Fulvio Calabria's avatar Nicola Fulvio Calabria
Browse files

Preparatory commit + partial development commit for moveNode

parent bc81d824
Loading
Loading
Loading
Loading
Loading
+38 −5
Original line number Diff line number Diff line
@@ -24,15 +24,39 @@ public class JobService {
    @Autowired
    private UriService uriService;
    
    @Autowired
    private MoveService moveService;

    @Autowired
    private AsyncTransferService asyncTransfService;

    public enum JobType {
    public enum JobDirection {
        pullToVoSpace,
        pullFromVoSpace,
        pushToVoSpace,
        pushFromVoSpace,
        moveNode,
        copyNode
        copyNode;

        public static JobDirection getJobDirectionEnumFromTransfer(Transfer transfer) {
            String direction = transfer.getDirection();
            switch (direction) {
                case "pullToVoSpace":
                case "pullFromVoSpace":
                case "pushToVoSpace":
                case "pushFromVoSpace":
                    return JobDirection.valueOf(direction);

                default:
                    if (transfer.isKeepBytes()) {
                        return JobDirection.copyNode;
                    } else {
                        return JobDirection.moveNode;
                    }

            }
        }

    }

    public void setJobPhase(JobSummary job, String phase) {
@@ -67,7 +91,7 @@ public class JobService {

            jobDAO.updateJob(job);

            switch (getJobType(transfer)) {
            switch (getJobDirection(transfer)) {
                case pullToVoSpace:
                    handlePullToVoSpace(job, transfer);
                    break;
@@ -75,6 +99,10 @@ public class JobService {
                case pushToVoSpace:
                    handleVoSpaceUrlsListResult(job, transfer);
                    break;
                case moveNode:
                    throw new UnsupportedOperationException("Not implemented yet");
                    // handleMoveNode(job, transfer);
                    // break;
                default:
                    throw new UnsupportedOperationException("Not implemented yet");
            }
@@ -114,8 +142,13 @@ public class JobService {
        uriService.setTransferJobResult(job, transfer);
    }
    
    private JobType getJobType(Transfer transfer) {
        return JobType.valueOf(transfer.getDirection());
    private void handleMoveNode(JobSummary job, Transfer transfer)
    {
        moveService.processMoveJob(job, transfer);
    }

    private JobDirection getJobDirection(Transfer transfer) {
        return JobDirection.getJobDirectionEnumFromTransfer(transfer);
    }

    /**
+98 −0
Original line number Diff line number Diff line
package it.inaf.oats.vospace;

import it.inaf.ia2.aa.data.User;
import it.inaf.oats.vospace.datamodel.NodeProperties;
import it.inaf.oats.vospace.datamodel.NodeUtils;
import it.inaf.oats.vospace.exception.NodeBusyException;
import it.inaf.oats.vospace.exception.PermissionDeniedException;
import it.inaf.oats.vospace.persistence.NodeDAO;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import net.ivoa.xml.uws.v1.JobSummary;
import net.ivoa.xml.vospace.v2.Node;
import net.ivoa.xml.vospace.v2.Transfer;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class MoveService {

    @Autowired
    private NodeDAO nodeDao;

    @Autowired
    private HttpServletRequest servletRequest;

    public void processMoveJob(JobSummary job, Transfer transfer) {

        // Get Source Path
        String sourcePath = transfer.getTarget();

        // Get Destination Path (it's in transfer direction)
        String destinationPath = transfer.getDirection();

        // Extract User permissions from servlet request
        User user = (User) servletRequest.getUserPrincipal();

        Long sourceId = nodeDao.getNodeId(sourcePath);
        List<Node> branchList = nodeDao.listNodesInBranch(sourceId, true);
        
        // Check feasibility of move on source branch
        if (!isWritePermissionsValid(branchList, user)) {
            throw new PermissionDeniedException(sourcePath);
        }
        
        if(sourcePath.equals(destinationPath))
            return;
        
        if(!isMoveable(branchList)) {
            throw new NodeBusyException(sourcePath);
        }
        
        // Set branch at busy        
        nodeDao.setBranchBusy(sourceId, true);
               
        
        // Compare source and destination paths and see if it's just a rename
        if(NodeUtils.getParentPath(sourcePath).equals(NodeUtils.getParentPath(destinationPath)))
        {           
            nodeDao.renameNode(sourceId, NodeUtils.getLastPathElement(destinationPath));
        } else {
            this.moveNode(sourceId, sourcePath, destinationPath, user);
        }

        nodeDao.setBranchBusy(sourceId, false);
        
    }

    // All nodes must be writable by the user to have a true
    private boolean isWritePermissionsValid(List<Node> list, User user) {
        String userName = user.getName();
        List<String> userGroups = user.getGroups();

        return list.stream().allMatch((n) -> {
            return NodeUtils.checkIfWritable(n, userName, userGroups);
        });

    }

    // All nodes must comply to have a true            
    private boolean isMoveable(List<Node> list) {
        return list.stream().allMatch((n) -> {
            boolean busy = NodeUtils.getIsBusy(n);
            boolean sticky
                    = Boolean.valueOf(
                            NodeProperties.getNodePropertyByURI(n,
                                    NodeProperties.STICKY_URN));

            return (!busy && !sticky);
        });
    }
       
    
    private void moveNode(Long sourceId, String sourcePath, String destPath, User user)
    {
        
    }

}
+2 −2
Original line number Diff line number Diff line
@@ -169,7 +169,7 @@ public class TransferController {
            @RequestParam(value = "PHASE", required = false) Optional<List<ExecutionPhase>> phase,
            @RequestParam(value = "AFTER", required = false) @DateTimeFormat(iso = DateTimeFormat.ISO.DATE_TIME) Optional<LocalDateTime> after,
            @RequestParam(value = "LAST", required = false) Optional<Integer> last,
            @RequestParam(value = "direction", required = false) Optional<List<JobService.JobType>> direction,
            @RequestParam(value = "direction", required = false) Optional<List<JobService.JobDirection>> direction,
            User principal) {

        if (last.isPresent()) {
@@ -187,7 +187,7 @@ public class TransferController {
            phaseList = List.of();
        }

        List<JobService.JobType> directionList;
        List<JobService.JobDirection> directionList;
        if (direction.isPresent()) {
            directionList = direction.get();
        } else {
+10 −5
Original line number Diff line number Diff line
@@ -3,7 +3,7 @@ package it.inaf.oats.vospace;
import it.inaf.ia2.aa.ServletRapClient;
import it.inaf.ia2.aa.data.User;
import it.inaf.ia2.rap.client.call.TokenExchangeRequest;
import it.inaf.oats.vospace.JobService.JobType;
import it.inaf.oats.vospace.JobService.JobDirection;
import it.inaf.oats.vospace.datamodel.NodeProperties;
import it.inaf.oats.vospace.datamodel.NodeUtils;
import static it.inaf.oats.vospace.datamodel.NodeUtils.urlEncodePath;
@@ -82,16 +82,20 @@ public class UriService {
            throw new InvalidArgumentException("Transfer contains no protocols");
        }

        JobService.JobType jobType = JobType.valueOf(transfer.getDirection());
        JobService.JobDirection jobDirection
                = JobDirection.getJobDirectionEnumFromTransfer(transfer);

        List<String> validProtocolUris = new ArrayList<>();
        switch (jobType) {
        switch (jobDirection) {
            case pullFromVoSpace:
                validProtocolUris.add("ivo://ivoa.net/vospace/core#httpget");
                break;
            case pushToVoSpace:
                validProtocolUris.add("ivo://ivoa.net/vospace/core#httpput");
                break;

            default:
                throw new InternalFaultException("Unsupported job direction specified");
        }

        List<Protocol> validProtocols
@@ -113,7 +117,7 @@ public class UriService {
    }

    private Node getEndpointNode(String relativePath,
            JobService.JobType jobType,
            JobService.JobDirection jobType,
            User user) {
        Optional<Node> optNode = nodeDao.listNode(relativePath);
        if (optNode.isPresent()) {
@@ -142,7 +146,8 @@ public class UriService {
        List<String> groups = user.getGroups();

        // Check privileges write or read according to job type
        JobService.JobType jobType = JobType.valueOf(transfer.getDirection());
        JobService.JobDirection jobType = 
                JobDirection.getJobDirectionEnumFromTransfer(transfer);
        Node node = this.getEndpointNode(relativePath, jobType, user);

        switch (jobType) {
+3 −3
Original line number Diff line number Diff line
@@ -55,7 +55,7 @@ public class JobDAO {
            int i = 0;
            ps.setString(++i, jobSummary.getJobId());
            ps.setString(++i, jobSummary.getOwnerId());
            ps.setObject(++i, getJobType(jobSummary), Types.OTHER);
            ps.setObject(++i, getJobDirection(jobSummary), Types.VARCHAR);
            ps.setObject(++i, jobSummary.getPhase().value(), Types.OTHER);
            ps.setObject(++i, toJson(jobSummary.getJobInfo()), Types.OTHER);
            
@@ -74,7 +74,7 @@ public class JobDAO {
        });
    }

    private String getJobType(JobSummary jobSummary) {
    private String getJobDirection(JobSummary jobSummary) {

        List<Object> payload = jobSummary.getJobInfo().getAny();
        if (payload.isEmpty()) {
@@ -138,7 +138,7 @@ public class JobDAO {

    public Jobs getJobs(String userId,
            List<ExecutionPhase> phaseList,
            List<JobService.JobType> directionList,
            List<JobService.JobDirection> directionList,
            Optional<LocalDateTime> after,
            Optional<Integer> last
    ) {
Loading