/*
* Copyright 2011, MyCellar
*
* This file is part of MyCellar.
*
* MyCellar is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* MyCellar is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with MyCellar. If not, see <http://www.gnu.org/licenses/>.
*/
package fr.mycellar.interfaces.web.services.admin;
import java.util.ArrayList;
import java.util.List;
import javax.inject.Inject;
import javax.inject.Named;
import javax.inject.Singleton;
import javax.ws.rs.Consumes;
import javax.ws.rs.DefaultValue;
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 jpasearch.repository.query.SearchParameters;
import fr.mycellar.domain.admin.Configuration;
import fr.mycellar.domain.shared.exception.BusinessException;
import fr.mycellar.interfaces.facades.admin.AdministrationServiceFacade;
import fr.mycellar.interfaces.web.services.FilterCouple;
import fr.mycellar.interfaces.web.services.ListWithCount;
import fr.mycellar.interfaces.web.services.OrderCouple;
import fr.mycellar.interfaces.web.services.SearchParametersUtil;
/**
* @author speralta
*/
@Named
@Singleton
@Path("/admin/domain/admin")
public class AdminDomainWebService {
private AdministrationServiceFacade administrationServiceFacade;
private SearchParametersUtil searchParametersUtil;
// --------------
// CONFIGURATION
// --------------
@GET
@Produces(MediaType.APPLICATION_JSON)
@Path("configurations")
public ListWithCount<Configuration> getConfigurations( //
@QueryParam("first") int first, //
@QueryParam("count") @DefaultValue("20") int count, //
@QueryParam("filters") List<FilterCouple> filters, //
@QueryParam("sort") List<OrderCouple> orders) {
SearchParameters<Configuration> searchParameters = searchParametersUtil.getSearchParameters(first, count, filters, orders, Configuration.class);
List<Configuration> configurations;
if (count == 0) {
configurations = new ArrayList<>();
} else {
configurations = administrationServiceFacade.getConfigurations(searchParameters);
}
return new ListWithCount<>(administrationServiceFacade.countConfigurations(searchParameters), configurations);
}
@GET
@Produces(MediaType.APPLICATION_JSON)
@Path("configurations/{id}")
public Configuration getConfigurationById(@PathParam("id") int configurationId) {
return administrationServiceFacade.getConfigurationById(configurationId);
}
@POST
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
@Path("configurations/{id}")
public Configuration saveConfiguration(@PathParam("id") int configurationId, Configuration configuration) throws BusinessException {
if ((configurationId == configuration.getId()) && (getConfigurationById(configurationId) != null)) {
return administrationServiceFacade.saveConfiguration(configuration);
}
throw new RuntimeException();
}
// BEANS Methods
@Inject
public void setAdministrationServiceFacade(AdministrationServiceFacade administrationServiceFacade) {
this.administrationServiceFacade = administrationServiceFacade;
}
@Inject
public void setSearchParametersUtil(SearchParametersUtil searchParametersUtil) {
this.searchParametersUtil = searchParametersUtil;
}
}