* implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
+
package org.akraino.validation.ui.controller;
import java.util.List;
import org.akraino.validation.ui.entity.Blueprint;
-import org.akraino.validation.ui.service.BlueprintService;
-import org.apache.log4j.Logger;
+import org.akraino.validation.ui.service.DbAdapter;
+import org.onap.portalsdk.core.controller.RestrictedBaseController;
+import org.onap.portalsdk.core.logging.logic.EELFLoggerDelegate;
+import org.onap.portalsdk.core.web.support.UserUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
-import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.stereotype.Controller;
+import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.web.bind.annotation.RequestMethod;
+
+@Controller
+@RequestMapping("/api/v1/blueprint")
+public class BlueprintController extends RestrictedBaseController {
-@RestController
-@RequestMapping("/api/blueprint")
-public class BlueprintController {
+ private static final EELFLoggerDelegate LOGGER = EELFLoggerDelegate.getLogger(BlueprintController.class);
@Autowired
- BlueprintService service;
+ DbAdapter service;
- private static final Logger LOGGER = Logger.getLogger(BlueprintController.class);
+ public BlueprintController() {
+ super();
+ }
- @GetMapping("/")
+ @RequestMapping(value = { "/" }, method = RequestMethod.GET)
public ResponseEntity<List<Blueprint>> getBlueprints() {
try {
return new ResponseEntity<>(service.getBlueprints(), HttpStatus.OK);
} catch (Exception e) {
- LOGGER.error(e);
+ LOGGER.error(EELFLoggerDelegate.errorLogger,
+ "Error when trying to get blueprints. " + UserUtils.getStackTrace(e));
}
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(null);
}
+ @RequestMapping(value = { "/" }, method = RequestMethod.POST)
+ public ResponseEntity<Blueprint> createBlueprint(@RequestBody Blueprint blueprint) {
+ try {
+ service.saveBlueprint(blueprint);
+ return new ResponseEntity<>(blueprint, HttpStatus.OK);
+ } catch (Exception e) {
+ LOGGER.error(EELFLoggerDelegate.errorLogger, "Creation of blueprint failed. " + UserUtils.getStackTrace(e));
+ return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(null);
+ }
+ }
+
+ @RequestMapping(value = { "/" }, method = RequestMethod.DELETE)
+ public ResponseEntity<Boolean> deleteBlueprint(@RequestBody Blueprint blueprint) {
+ try {
+ service.deleteBlueprint(blueprint);
+ return new ResponseEntity<>(true, HttpStatus.OK);
+ } catch (Exception e) {
+ LOGGER.error(EELFLoggerDelegate.errorLogger, "Deletion of blueprint failed. " + UserUtils.getStackTrace(e));
+ return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(null);
+ }
+ }
}