1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
/*
* ============LICENSE_START=======================================================
* Copyright (C) 2021 Nokia
* ================================================================================
* 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
* 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.
*
* SPDX-License-Identifier: Apache-2.0
* ============LICENSE_END=========================================================
*/
package org.openecomp.sdc.validation.impl.util;
import org.apache.http.HttpEntity;
import org.apache.http.entity.ContentType;
import org.apache.http.entity.mime.MultipartEntityBuilder;
import org.openecomp.sdc.common.http.client.api.HttpExecuteException;
import org.openecomp.sdc.common.http.client.api.HttpRequestHandler;
import org.openecomp.sdc.common.http.client.api.HttpResponse;
import org.openecomp.sdc.common.http.config.HttpClientConfig;
import org.openecomp.sdc.common.http.config.Timeouts;
import org.openecomp.sdc.logging.api.Logger;
import org.openecomp.sdc.logging.api.LoggerFactory;
import org.openecomp.sdc.validation.type.helmvalidator.HelmValidatorConfig;
public class HelmValidatorHttpClient {
private static final Logger LOGGER = LoggerFactory.getLogger(HelmValidatorHttpClient.class);
private static final int TIMEOUT_MS = 10000;
private static final String FILE = "file";
private static final String IS_LINTED = "isLinted";
private static final String IS_STRICT_LINTED = "isStrictLinted";
private static final String VERSION_DESIRED = "versionDesired";
private final HttpRequestHandler httpRequestHandler;
public HelmValidatorHttpClient(HttpRequestHandler httpRequestHandler) {
this.httpRequestHandler = httpRequestHandler;
}
public HttpResponse<String> execute(String fileName, byte[] helmChartFile, HelmValidatorConfig validatorConfig) throws Exception{
LOGGER.info("Trying to execute Helm chart validation. File name: {}", fileName);
try {
HttpEntity entity = MultipartEntityBuilder.create()
.addBinaryBody(FILE, helmChartFile, ContentType.DEFAULT_BINARY, fileName)
.addTextBody(IS_LINTED, getString(validatorConfig.isLintable()))
.addTextBody(IS_STRICT_LINTED, getString(validatorConfig.isStrictLintable()))
.addTextBody(VERSION_DESIRED, validatorConfig.getVersion())
.build();
HttpResponse<String> httpResponse = httpRequestHandler.post(validatorConfig.getValidatorUrl(),
null, entity, new HttpClientConfig(new Timeouts(TIMEOUT_MS, TIMEOUT_MS)));
LOGGER.info("Received response from Helm chart validator with code {}", httpResponse.getStatusCode());
LOGGER.debug("Response from Helm chart validator: {}", httpResponse);
return httpResponse;
} catch (HttpExecuteException e) {
LOGGER.info("Exception during call to Helm validator {}", e.getMessage());
}
throw new Exception("Http response is invalid.");
}
private String getString(boolean helmValidatorConfig) {
return Boolean.toString(helmValidatorConfig);
}
}
|