/* * Electronic Logistics Management Information System (eLMIS) is a supply chain management system for health commodities in a developing country setting. * * Copyright (C) 2015 John Snow, Inc (JSI). This program was produced for the U.S. Agency for International Development (USAID). It was prepared under the USAID | DELIVER PROJECT, Task Order 4. * * This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. * * This program 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 Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ package org.openlmis.restapi.controller; import com.wordnik.swagger.annotations.Api; import com.wordnik.swagger.annotations.ApiOperation; import com.wordnik.swagger.annotations.ApiResponse; import com.wordnik.swagger.annotations.ApiResponses; import org.openlmis.report.model.dto.StockStatusDTO; import org.openlmis.report.service.StockStatusService; import org.openlmis.restapi.response.RestResponse; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.ResponseEntity; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import java.security.Principal; import static org.springframework.web.bind.annotation.RequestMethod.GET; @Controller @Api(value="Stock Status", description = "Returns monthly and quarterly stock status", position = 0) public class StockStatusController extends BaseController { @Autowired private StockStatusService service; @ApiOperation(value = "Returns stock status details", notes = "Returns a complete list stock status for selected program.", response = StockStatusDTO.class) @ApiResponses(value = { @ApiResponse(code = 200, message = "Successful retrieval of Stock Status detail", response = StockStatusDTO.class), @ApiResponse(code = 404, message = "Given program does not exist"), @ApiResponse(code = 500, message = "Internal server error")} ) @RequestMapping(value = "/rest-api/stock-status/quarter", method = GET, headers = ACCEPT_JSON) public ResponseEntity getStockStatusQuarterly( @RequestParam("quarter") Long quarter, @RequestParam("year") Long year, @RequestParam("program") String program, Principal principal) { return RestResponse.response("report", service.getStockStatusByQuarter(program, year, quarter, loggedInUserId(principal))); } @ApiOperation(value = "Returns stock status details", notes = "Returns a complete list stock status for selected program.", response = StockStatusDTO.class) @ApiResponses(value = { @ApiResponse(code = 200, message = "Successful retrieval of Stock Status detail", response = StockStatusDTO.class), @ApiResponse(code = 404, message = "Given program does not exist"), @ApiResponse(code = 500, message = "Internal server error")} ) @RequestMapping(value = "/rest-api/stock-status/monthly", method = GET, headers = ACCEPT_JSON) public ResponseEntity getStockStatusMonthly( @RequestParam("month") Long month, @RequestParam("year") Long year, @RequestParam("program") String program, Principal principal) { return RestResponse.response("report", service.getStockStatusByMonth(program, year, month,loggedInUserId(principal))); } }