package org.ourgrid.broker.communication.sender; import org.ourgrid.broker.response.RequestWorkersResponseTO; import org.ourgrid.common.interfaces.LocalWorkerProvider; import org.ourgrid.common.interfaces.to.RequestSpecification; import org.ourgrid.common.internal.SenderIF; import org.ourgrid.common.specification.job.JobSpecification; import br.edu.ufcg.lsd.commune.container.servicemanager.ServiceManager; import br.edu.ufcg.lsd.commune.identification.ServiceID; import br.edu.ufcg.lsd.commune.network.certification.CertificationUtils; public class RequestWorkersSender implements SenderIF<RequestWorkersResponseTO> { public void execute(RequestWorkersResponseTO response, ServiceManager manager) { CertificationUtils.getCertSubjectDN(manager.getMyCertPath()); JobSpecification jobSpec = response.getJobSpec(); RequestSpecification spec = new RequestSpecification(response.getJobID(), jobSpec, response.getRequestID(), jobSpec.getRequirements(), response.getRequiredWorkers(), response.getMaxFails(), response.getMaxReplicas(), manager.getMyCertPath()); LocalWorkerProvider lwp = (LocalWorkerProvider) manager.getStub(ServiceID.parse(response.getPeerAddress()), LocalWorkerProvider.class); lwp.requestWorkers(spec); } }