2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017-2018 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
7 * Copyright (C) 2017 Amdocs
8 * =============================================================================
9 * Licensed under the Apache License, Version 2.0 (the "License");
10 * you may not use this file except in compliance with the License.
11 * You may obtain a copy of the License at
13 * http://www.apache.org/licenses/LICENSE-2.0
15 * Unless required by applicable law or agreed to in writing, software
16 * distributed under the License is distributed on an "AS IS" BASIS,
17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 * See the License for the specific language governing permissions and
19 * limitations under the License.
21 * ============LICENSE_END=========================================================
24 package org.onap.appc.provider.lcm.util;
26 import java.text.ParseException;
27 import java.text.SimpleDateFormat;
28 import java.util.TimeZone;
30 import org.apache.commons.lang3.StringUtils;
31 import org.opendaylight.yang.gen.v1.org.onap.appc.lcm.rev160108.Payload;
32 import org.opendaylight.yang.gen.v1.org.onap.appc.lcm.rev160108.action.identifiers.ActionIdentifiers;
33 import org.opendaylight.yang.gen.v1.org.onap.appc.lcm.rev160108.common.header.CommonHeader;
34 import org.opendaylight.yang.gen.v1.org.onap.appc.lcm.rev160108.common.header.common.header.Flags;
35 import org.onap.appc.domainmodel.lcm.ActionLevel;
36 import org.onap.appc.domainmodel.lcm.RequestContext;
37 import org.onap.appc.domainmodel.lcm.VNFOperation;
38 import org.onap.appc.requesthandler.objects.RequestHandlerInput;
39 import com.att.eelf.configuration.EELFLogger;
40 import com.att.eelf.configuration.EELFManager;
44 public class RequestInputBuilder {
45 private final EELFLogger logger = EELFManager.getInstance().getApplicationLogger();
47 private static final String FORMAT = "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'";
49 private RequestContext requestContext;
50 private String rpcName;
53 public RequestInputBuilder requestContext() {
54 this.requestContext = new RequestContext();
58 public RequestInputBuilder action(String action) {
59 this.requestContext.setAction(VNFOperation.findByString(action));
64 public RequestInputBuilder additionalContext(String key, String value) {
65 this.requestContext.addKeyValueToAdditionalContext(key, value);
69 public RequestInputBuilder payload(Payload payload) {
70 if (payload != null) {
71 this.requestContext.setPayload(payload.getValue());
76 public RequestHandlerInput build (){
77 RequestHandlerInput request = new RequestHandlerInput();
78 request.setRequestContext(this.requestContext);
79 request.setRpcName(rpcName);
83 public RequestInputBuilder rpcName(String rpcName) {
84 this.rpcName = rpcName;
88 public RequestInputBuilder commonHeader(CommonHeader commonHeader) throws ParseException {
89 org.onap.appc.domainmodel.lcm.CommonHeader header = new org.onap.appc.domainmodel.lcm.CommonHeader();
90 this.requestContext.setCommonHeader(header);
93 if(null != commonHeader.getTimestamp()) {
94 SimpleDateFormat format = new SimpleDateFormat(FORMAT);
95 format.setLenient(false);
96 format.setTimeZone(TimeZone.getTimeZone("UTC"));
97 header.setTimestamp(format.parse(commonHeader.getTimestamp().getValue()));
99 throw new ParseException("Missing mandatory parameter : timestamp " , 0);
101 } catch (ParseException e) {
102 logger.error(String.format("DATE format is incorrect: %s", e.getMessage()));
105 header.setApiVer(commonHeader.getApiVer());
106 header.setRequestId(commonHeader.getRequestId());
107 header.setOriginatorId(commonHeader.getOriginatorId());
108 header.setSubRequestId(commonHeader.getSubRequestId());
110 Flags inFlags = commonHeader.getFlags();
111 org.onap.appc.domainmodel.lcm.Flags flags = new org.onap.appc.domainmodel.lcm.Flags();
112 if (inFlags != null) {
114 if(null != inFlags.getForce()) {
115 flags.setForce(Boolean.parseBoolean(inFlags.getForce().toString().toLowerCase()));
117 if(null!=inFlags.getMode()) {
118 flags.setMode(inFlags.getMode().name());
120 if(null!= inFlags.getTtl()) {
121 flags.setTtl(inFlags.getTtl());
125 this.requestContext.getCommonHeader().setFlags(flags);
129 public RequestInputBuilder actionIdentifiers(ActionIdentifiers actionIdentifiers) throws ParseException {
130 if(null!= actionIdentifiers) {
131 org.onap.appc.domainmodel.lcm.ActionIdentifiers actionIds = new org.onap.appc.domainmodel.lcm.ActionIdentifiers();
132 actionIds.setServiceInstanceId(actionIdentifiers.getServiceInstanceId());
133 actionIds.setVnfcName(actionIdentifiers.getVnfcName());
134 actionIds.setvServerId(actionIdentifiers.getVserverId());
135 actionIds.setVnfId(actionIdentifiers.getVnfId());
136 actionIds.setVfModuleId(actionIdentifiers.getVfModuleId());
137 this.requestContext.setActionIdentifiers(actionIds);
139 ActionLevel actionLevel=ActionLevel.VNF;
140 this.requestContext.setActionLevel(actionLevel);
143 throw new ParseException("Missing action identifier" , 0);