package org.openstack.atlas.api.resources; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.openstack.atlas.api.helpers.ResponseFactory; import org.openstack.atlas.api.repository.ValidatorRepository; import org.openstack.atlas.api.resources.providers.CommonDependencyProvider; import org.openstack.atlas.api.validation.context.HttpRequestType; import org.openstack.atlas.api.validation.results.ValidatorResult; import org.openstack.atlas.docs.loadbalancers.api.v1.Meta; import org.openstack.atlas.service.domain.entities.LoadBalancer; import javax.ws.rs.*; import javax.ws.rs.core.HttpHeaders; import javax.ws.rs.core.Response; import static javax.ws.rs.core.MediaType.APPLICATION_JSON; import static javax.ws.rs.core.MediaType.APPLICATION_XML; public class LoadbalancerMetaResource extends CommonDependencyProvider { private final Log LOG = LogFactory.getLog(LoadbalancerMetaResource.class); private HttpHeaders requestHeaders; private Integer accountId; private Integer loadBalancerId; private Integer id; @GET @Produces({APPLICATION_XML, APPLICATION_JSON}) public Response retrieveMeta() { org.openstack.atlas.service.domain.entities.LoadbalancerMeta domainLoadbalancerMeta; Meta apiMeta; try { domainLoadbalancerMeta = loadbalancerMetadataService.getLoadbalancerMeta(accountId, loadBalancerId, id); apiMeta = dozerMapper.map(domainLoadbalancerMeta, org.openstack.atlas.docs.loadbalancers.api.v1.Meta.class); return Response.status(Response.Status.OK).entity(apiMeta).build(); } catch (Exception e) { return ResponseFactory.getErrorResponse(e, null, null); } } @PUT @Consumes({APPLICATION_XML, APPLICATION_JSON}) public Response updateMeta(Meta meta) { ValidatorResult result = ValidatorRepository.getValidatorFor(Meta.class).validate(meta, HttpRequestType.PUT); if (!result.passedValidation()) { return getValidationFaultResponse(result); } try { meta.setId(id); org.openstack.atlas.docs.loadbalancers.api.v1.LoadBalancer apiLb = new org.openstack.atlas.docs.loadbalancers.api.v1.LoadBalancer(); apiLb.getMetadata().add(meta); LoadBalancer domainLb = dozerMapper.map(apiLb, LoadBalancer.class); domainLb.setId(loadBalancerId); domainLb.setAccountId(accountId); loadbalancerMetadataService.updateLoadbalancerMeta(domainLb); return Response.status(Response.Status.OK).build(); } catch (Exception e) { return ResponseFactory.getErrorResponse(e, null, null); } } @DELETE public Response deleteMeta() { try { loadbalancerMetadataService.deleteLoadbalancerMeta(accountId, loadBalancerId, id); return Response.status(Response.Status.OK).build(); } catch (Exception e) { return ResponseFactory.getErrorResponse(e, null, null); } } public void setRequestHeaders(HttpHeaders requestHeaders) { this.requestHeaders = requestHeaders; } public void setAccountId(Integer accountId) { this.accountId = accountId; } public void setLoadBalancerId(Integer loadBalancerId) { this.loadBalancerId = loadBalancerId; } public void setId(Integer id) { this.id = id; } }