/**
- * Copyright (c) 2018 Orange
+ * Copyright (c) 2018 Orange
*
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
*
- * http://www.apache.org/licenses/LICENSE-2.0
+ * http://www.apache.org/licenses/LICENSE-2.0
*
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
+ * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
+ * an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations under the License.
*/
package org.onap.nbi.apis.serviceorder;
+import java.util.List;
+import java.util.Optional;
+import javax.validation.Valid;
import org.onap.nbi.apis.serviceorder.model.ServiceOrder;
import org.onap.nbi.apis.serviceorder.model.StateType;
import org.onap.nbi.apis.serviceorder.model.orchestrator.ServiceOrderInfo;
import org.springframework.http.ResponseEntity;
import org.springframework.util.MultiValueMap;
import org.springframework.validation.Errors;
-import org.springframework.web.bind.annotation.*;
-
-import javax.validation.Valid;
-import java.util.List;
+import org.springframework.web.bind.annotation.DeleteMapping;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PathVariable;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.PutMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestParam;
+import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("/serviceOrder")
MultiCriteriaRequestBuilder multiCriteriaRequestBuilder;
-
-
@GetMapping(value = "/{serviceOrderId}", produces = MediaType.APPLICATION_JSON_VALUE)
public ResponseEntity<Object> getServiceOrder(@PathVariable String serviceOrderId,
- @RequestParam MultiValueMap<String, String> params) {
+ @RequestParam MultiValueMap<String, String> params) {
- ServiceOrder serviceOrder = serviceOrderService.findServiceOrderById(serviceOrderId);
- if (serviceOrder == null) {
+ Optional<ServiceOrder> optionalServiceOrder = serviceOrderService.findServiceOrderById(serviceOrderId);
+ if (!optionalServiceOrder.isPresent()) {
return ResponseEntity.notFound().build();
}
JsonRepresentation filter = new JsonRepresentation(params);
- return this.getResponse(serviceOrder, filter);
+ return this.getResponse(optionalServiceOrder.get(), filter);
}
@GetMapping(value = "", produces = MediaType.APPLICATION_JSON_VALUE)
@PostMapping(consumes = MediaType.APPLICATION_JSON_VALUE)
public ResponseEntity<Object> createServiceOrder(@Valid @RequestBody ServiceOrder serviceOrder, Errors errors,
- @RequestParam MultiValueMap<String, String> params) {
-
+ @RequestParam MultiValueMap<String, String> params) {
if (errors != null && errors.hasErrors()) {
throw new ValidationException(errors.getAllErrors());
}
- ServiceOrder serviceOrderSaved =serviceOrderService.createServiceOrder(serviceOrder);
+ ServiceOrder serviceOrderSaved = serviceOrderService.createServiceOrder(serviceOrder);
JsonRepresentation filter = new JsonRepresentation(params);
return this.createResponse(serviceOrderSaved, filter);
}
- @PutMapping(value = "/test/{serviceOrderId}",consumes = MediaType.APPLICATION_JSON_VALUE)
- public ResponseEntity<Object> checkServiceOrderRessource(@PathVariable String serviceOrderId,@RequestParam MultiValueMap<String, String> params){
- ServiceOrder serviceOrder = serviceOrderService.findServiceOrderById(serviceOrderId);
- serviceOrder = checkServiceOrder(serviceOrder);
+ @PutMapping(value = "/test/{serviceOrderId}", consumes = MediaType.APPLICATION_JSON_VALUE)
+ public ResponseEntity<Object> checkServiceOrderRessource(@PathVariable String serviceOrderId,
+ @RequestParam MultiValueMap<String, String> params) {
+ Optional<ServiceOrder> optionalServiceOrder = serviceOrderService.findServiceOrderById(serviceOrderId);
+ if (!optionalServiceOrder.isPresent()) {
+ return ResponseEntity.notFound().build();
+ }
+ ServiceOrder serviceOrder = checkServiceOrder(optionalServiceOrder.get());
JsonRepresentation filter = new JsonRepresentation(params);
- return this.createResponse(serviceOrder,filter);
+ return this.createResponse(serviceOrder, filter);
}
} else if (serviceOrderInfo.isAllItemsCompleted()) {
serviceOrderService.updateOrderState(serviceOrder, StateType.COMPLETED);
} else {
- createAAICustomer.createAAICustomer(serviceOrder,serviceOrderInfo);
- if(StateType.ACKNOWLEDGED==serviceOrder.getState()) {
+ createAAICustomer.createAAICustomer(serviceOrder, serviceOrderInfo);
+ if (StateType.ACKNOWLEDGED == serviceOrder.getState()) {
createAAIServiceType.createAAIServiceType(serviceOrder, serviceOrderInfo);
- if(StateType.ACKNOWLEDGED==serviceOrder.getState()) {
+ if (StateType.ACKNOWLEDGED == serviceOrder.getState()) {
serviceOrchestratorManager.registerServiceOrder(serviceOrder, serviceOrderInfo);
}
}