
com.hubspot.singularity.resources.SlaveResource Maven / Gradle / Ivy
package com.hubspot.singularity.resources;
import java.util.List;
import javax.ws.rs.DELETE;
import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.QueryParam;
import javax.ws.rs.core.MediaType;
import com.google.common.base.Optional;
import com.google.inject.Inject;
import com.hubspot.mesos.JavaUtils;
import com.hubspot.singularity.MachineState;
import com.hubspot.singularity.SingularityAction;
import com.hubspot.singularity.SingularityMachineStateHistoryUpdate;
import com.hubspot.singularity.SingularityService;
import com.hubspot.singularity.SingularitySlave;
import com.hubspot.singularity.SingularityUser;
import com.hubspot.singularity.api.SingularityMachineChangeRequest;
import com.hubspot.singularity.auth.SingularityAuthorizationHelper;
import com.hubspot.singularity.data.SingularityValidator;
import com.hubspot.singularity.data.SlaveManager;
import com.hubspot.singularity.expiring.SingularityExpiringMachineState;
import com.wordnik.swagger.annotations.Api;
import com.wordnik.swagger.annotations.ApiOperation;
import com.wordnik.swagger.annotations.ApiParam;
@Path(SlaveResource.PATH)
@Produces({ MediaType.APPLICATION_JSON })
@Api(description="Manages Singularity slaves.", value=SlaveResource.PATH)
public class SlaveResource extends AbstractMachineResource {
public static final String PATH = SingularityService.API_BASE_PATH + "/slaves";
@Inject
public SlaveResource(SlaveManager slaveManager, SingularityAuthorizationHelper authorizationHelper, Optional user, SingularityValidator validator) {
super(slaveManager, authorizationHelper, user, validator);
}
@Override
protected String getObjectTypeString() {
return "Slave";
}
@GET
@Path("/")
@ApiOperation("Retrieve the list of all known slaves, optionally filtering by a particular state")
public List getSlaves(@ApiParam("Optionally specify a particular state to filter slaves by") @QueryParam("state") Optional filterState) {
return manager.getObjectsFiltered(filterState);
}
@GET
@Path("/slave/{slaveId}")
@ApiOperation("Retrieve the history of a given slave")
public List getSlaveHistory(@ApiParam("Slave ID") @PathParam("slaveId") String slaveId) {
return manager.getHistory(slaveId);
}
@GET
@Path("/slave/{slaveId}/details")
@ApiOperation("Get information about a particular slave")
public Optional getSlave(@ApiParam("Slave ID") @PathParam("slaveId") String slaveId) {
return manager.getObject(slaveId);
}
@DELETE
@Path("/slave/{slaveId}")
@ApiOperation("Remove a known slave, erasing history. This operation will cancel decomissioning of the slave")
public void removeSlave(@ApiParam("Active SlaveId") @PathParam("slaveId") String slaveId) {
super.remove(slaveId);
}
@POST
@Path("/slave/{slaveId}/decommission")
@ApiOperation("Begin decommissioning a specific active slave")
public void decommissionSlave(@ApiParam("Active slaveId") @PathParam("slaveId") String slaveId, Optional changeRequest) {
super.decommission(slaveId, changeRequest, JavaUtils.getUserEmail(user), SingularityAction.DECOMMISSION_SLAVE);
}
@POST
@Path("/slave/{slaveId}/freeze")
@ApiOperation("Freeze tasks on a specific slave")
public void freezeSlave(@ApiParam("Slave ID") @PathParam("slaveId") String slaveId, Optional changeRequest) {
super.freeze(slaveId, changeRequest, JavaUtils.getUserEmail(user), SingularityAction.FREEZE_SLAVE);
}
@POST
@Path("/slave/{slaveId}/activate")
@ApiOperation("Activate a decomissioning slave, canceling decomission without erasing history")
public void activateSlave(@ApiParam("Active slaveId") @PathParam("slaveId") String slaveId, Optional changeRequest) {
super.activate(slaveId, changeRequest, JavaUtils.getUserEmail(user), SingularityAction.ACTIVATE_SLAVE);
}
@DELETE
@Path("/slave/{slaveId}/expiring")
@ApiOperation("Delete any expiring machine state changes for this slave")
public void deleteExpiringStateChange(@ApiParam("Active slaveId") @PathParam("slaveId") String slaveId) {
super.cancelExpiring(slaveId);
}
@GET
@Path("/expiring")
@ApiOperation("Get all expiring state changes for all slaves")
public List getExpiringStateChanges() {
return super.getExpiringStateChanges();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy