aboutsummaryrefslogtreecommitdiffstats
path: root/auth/cli-editor/src/main/java/org/onap/policy/apex/auth/clieditor/tosca/ApexCliToscaEditorMain.java
blob: 5f7bad116be63b5873b5774f9408001ce20271aa (plain)
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/*-
 * ============LICENSE_START=======================================================
 *  Copyright (C) 2019-2022 Nordix Foundation.
 * ================================================================================
 * 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.onap.policy.apex.auth.clieditor.tosca;

import java.io.IOException;
import java.util.Arrays;
import java.util.List;
import lombok.Getter;
import org.onap.policy.apex.auth.clieditor.ApexCommandLineEditorMain;
import org.onap.policy.apex.auth.clieditor.CommandLineParameters;
import org.onap.policy.apex.auth.clieditor.utils.CliUtils;
import org.onap.policy.common.utils.coder.CoderException;
import org.onap.policy.common.utils.resources.TextFileUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * This class initiates an Apex CLI Tosca editor.
 *
 * @author Ajith Sreekumar (ajith.sreekumar@est.tech)
 */
public class ApexCliToscaEditorMain {

    private static final Logger LOGGER = LoggerFactory.getLogger(ApexCliToscaEditorMain.class);

    @Getter
    private boolean failure;
    private ApexCliToscaParameters parameters;
    private ApexCommandLineEditorMain apexCliEditor;

    /**
     * Instantiates the Apex CLI Tosca editor.
     *
     * @param args the command line arguments
     */
    public ApexCliToscaEditorMain(final String[] args) {
        final var argumentString = Arrays.toString(args);
        LOGGER.info("Starting Apex CLI Tosca editor with arguments - {}", argumentString);

        final var parser = new ApexCliToscaParameterParser();
        parameters = parser.parse(args);
        if (parameters.isHelpSet()) {
            CliUtils.help(ApexCliToscaEditorMain.class.getName(), parser.getOptions());
            return;
        }
        parameters.validate();

        String policyModelFilePath = null;
        String nodeType = parameters.getNodeType();
        try {
            final var tempModelFile = TextFileUtils.createTempFile("policyModel", ".json");
            policyModelFilePath = tempModelFile.getAbsolutePath();
        } catch (IOException e) {
            LOGGER.error("Cannot create the policy model temp file.", e);
        }

        List<String> cliArgsList = CliUtils.generateArgumentsForCliEditor(parameters, parser.getOptionVariableMap(),
            CommandLineParameters.class);
        cliArgsList.add("-o");
        cliArgsList.add(policyModelFilePath);
        String[] cliArgs = cliArgsList.toArray(new String[cliArgsList.size()]);

        apexCliEditor = new ApexCommandLineEditorMain(cliArgs);
        if (apexCliEditor.getErrorCount() == 0) {
            LOGGER.info("Apex CLI editor completed execution. Creating the ToscaPolicy using the tosca template"
                + "skeleton file, config file, and policy model created.");

            // Create the ToscaPolicy using the tosca template skeleton file, config file, and policy model created.
            try {
                CliUtils.createToscaPolicy(parameters, policyModelFilePath, nodeType);
                LOGGER.info("Apex CLI Tosca editor completed execution.");
            } catch (IOException | CoderException e) {
                failure = true;
                LOGGER.error("Failed to create the Tosca template using the generated policy model,"
                    + "apex config file and the tosca template skeleton file. " + e);
            }

        } else {
            failure = true;
            LOGGER.error("execution of Apex command line editor failed: {} command execution failure(s) occurred",
                apexCliEditor.getErrorCount());
        }
    }

    /**
     * The main method, kicks off the cli tosca editor.
     *
     * @param args the arguments
     */
    public static void main(final String[] args) {
        new ApexCliToscaEditorMain(args);
    }
}