97a71973736b70cebede65def98919eb5c46e762
[so.git] / bpmn / so-bpmn-tasks / src / main / java / org / onap / so / bpmn / infrastructure / adapter / vnfm / tasks / VnfmAdapterUrlProvider.java
1 /*-
2  * ============LICENSE_START=======================================================
3  *  Copyright (C) 2019 Nordix Foundation.
4  * ================================================================================
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  *      http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  * SPDX-License-Identifier: Apache-2.0
18  * ============LICENSE_END=========================================================
19  */
20
21 package org.onap.so.bpmn.infrastructure.adapter.vnfm.tasks;
22
23 import java.net.URI;
24 import org.springframework.beans.factory.annotation.Autowired;
25 import org.springframework.stereotype.Service;
26 import org.springframework.web.util.UriComponentsBuilder;
27
28 /**
29  * 
30  * Provides VNFM adapter {@link java.net.URL}
31  * 
32  * @author waqas.ikram@est.tech
33  *
34  */
35 @Service
36 public class VnfmAdapterUrlProvider {
37
38   private final URI baseUri;
39
40   @Autowired
41   public VnfmAdapterUrlProvider(final VnfmBasicHttpConfigProvider etsiVnfmAdapter) {
42     this.baseUri = UriComponentsBuilder.fromHttpUrl(etsiVnfmAdapter.getUrl()).build().toUri();
43   }
44
45   /**
46    * Get VNFM create and instantiate URL
47    * 
48    * @param vnfId The identifier of the VNF. This must be the vnf-id of an existing generic-vnf in
49    *        AAI.
50    * @return VNFM create and instantiate URL
51    */
52   public String getCreateInstantiateUrl(final String vnfId) {
53     return UriComponentsBuilder.fromUri(baseUri).pathSegment("vnfs").pathSegment(vnfId).build().toString();
54   }
55
56   /**
57    * Get VNFM delete URL
58    * 
59    * @param vnfId The identifier of the VNF. This must be the vnf-id of an existing generic-vnf in
60    *        AAI.
61    * @return VNFM delete URL
62    */
63   public String getDeleteUrl(final String vnfId) {
64     return UriComponentsBuilder.fromUri(baseUri).pathSegment("vnfs").pathSegment(vnfId).build().toString();
65   }
66
67     /**
68      * Get job status URL
69      * 
70      * @param jobId The instantiation job identifier
71      * @return job status URL
72      */
73     public String getJobStatusUrl(final String jobId) {
74         return UriComponentsBuilder.fromUri(baseUri).pathSegment("jobs").pathSegment(jobId).build().toString();
75     }
76
77 }