All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.aeontronix.enhancedmule.tools.anypoint.application.deploy.DeploymentOperation Maven / Gradle / Ivy

There is a newer version: 2.0.0-alpha4
Show newest version
/*
 * Copyright (c) Aeontronix 2023
 */

package com.aeontronix.enhancedmule.tools.anypoint.application.deploy;

import com.aeontronix.commons.file.TempFile;
import com.aeontronix.commons.io.IOUtils;
import com.aeontronix.enhancedmule.tools.anypoint.Environment;
import com.aeontronix.enhancedmule.tools.anypoint.LegacyAnypointClient;
import com.aeontronix.enhancedmule.tools.anypoint.NotFoundException;
import com.aeontronix.enhancedmule.tools.anypoint.Organization;
import com.aeontronix.enhancedmule.tools.anypoint.api.ClientApplication;
import com.aeontronix.enhancedmule.tools.anypoint.application.DeploymentException;
import com.aeontronix.enhancedmule.tools.anypoint.exchange.ExchangeAssetDescriptor;
import com.aeontronix.enhancedmule.tools.anypoint.provisioning.ApplicationProvisioningService;
import com.aeontronix.enhancedmule.tools.anypoint.provisioning.ExchangeManagementClient;
import com.aeontronix.enhancedmule.tools.anypoint.provisioning.ProvisioningException;
import com.aeontronix.enhancedmule.tools.application.ApplicationDescriptor;
import com.aeontronix.enhancedmule.tools.application.api.APIDescriptor;
import com.aeontronix.enhancedmule.tools.application.api.APIProvisioningResult;
import com.aeontronix.enhancedmule.tools.application.api.ClientApplicationDescriptor;
import com.aeontronix.enhancedmule.tools.legacy.deploy.ApplicationSource;
import com.aeontronix.enhancedmule.tools.legacy.deploy.ExchangeApplicationSource;
import com.aeontronix.enhancedmule.tools.legacy.deploy.FileApplicationSource;
import com.aeontronix.enhancedmule.tools.runtime.DeploymentResult;
import com.aeontronix.enhancedmule.tools.util.EMTLogger;
import com.aeontronix.enhancedmule.tools.util.HttpException;
import com.aeontronix.enhancedmule.tools.util.HttpHelper;
import com.aeontronix.unpack.FileType;
import com.aeontronix.unpack.Unpacker;
import com.aeontronix.unpack.transformer.SetPropertyTransformer;
import com.aeontronix.unpack.transformer.Transformer;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.concurrent.TimeUnit;

import static com.aeontronix.commons.Required.CREATE;

public abstract class DeploymentOperation {
    private static final Logger logger = LoggerFactory.getLogger(DeploymentOperation.class);
    private static final EMTLogger elogger = new EMTLogger(logger);
    public static final String ANYPOINT_PLATFORM_CLIENT_ID = "anypoint.platform.client_id";
    public static final String ANYPOINT_PLATFORM_CLIENT_SECRET = "anypoint.platform.client_secret";
    protected RuntimeDeploymentRequest deploymentRequest;
    protected Environment environment;
    protected ApplicationSource source;

    public DeploymentOperation() {
    }

    public DeploymentOperation(RuntimeDeploymentRequest request, Environment environment, ApplicationSource source) {
        this.deploymentRequest = request;
        this.environment = environment;
        this.source = source;
    }

    public DeploymentResult deploy() throws ProvisioningException, IOException, HttpException, DeploymentException {
        LegacyAnypointClient client = environment.getClient();
        boolean tmpFile = false;
        try {
            environment = environment.refresh();
            APIProvisioningResult provisioningResult = null;
            List transformers = new ArrayList<>();
            final ApplicationDescriptor applicationDescriptor = deploymentRequest.getApplicationDescriptor();
            if (applicationDescriptor == null) {
                logger.info("no anypoint.json found, skipping provisioning");
            }
            if (applicationDescriptor != null && !deploymentRequest.isSkipProvisioning() ) {
                logger.debug("Found anypoint provisioning file, provisioning");
                if (logger.isDebugEnabled()) {
                    logger.debug(client.getJsonHelper().getJsonMapper().writeValueAsString(applicationDescriptor));
                }
                final Organization organization = environment.getOrganization();
                final ApplicationProvisioningService applicationProvisioningService = new ApplicationProvisioningService(client);
                boolean assetPublished = false;
                final ExchangeManagementClient exchangeManagementClient = new ExchangeManagementClient();
                if (applicationDescriptor.isAssetPublish()) {
                    final ExchangeAssetDescriptor asset = applicationDescriptor.getApi().getAsset();
                    assetPublished = exchangeManagementClient.publish(asset, organization, source, deploymentRequest);
                }
                provisioningResult = applicationProvisioningService.provision(applicationDescriptor, environment, deploymentRequest);
                final APIDescriptor apiDescriptor = applicationDescriptor.getApi();
                if (provisioningResult.getApi() != null && apiDescriptor.isInjectApiId()) {
                    final String apiIdProperty = apiDescriptor.getApiIdProperty();
                    if (apiIdProperty == null) {
                        throw new IllegalArgumentException("apiIdProperty musn't be null");
                    }
                    deploymentRequest.setOverrideProperty(apiIdProperty, provisioningResult.getApi().getId());
                    deploymentRequest.setOverrideProperty(ANYPOINT_PLATFORM_CLIENT_ID, environment.getClientId());
                    try {
                        final String clientSecret = environment.getClientSecret();
                        if (clientSecret != null) {
                            deploymentRequest.setSecureOverrideProperty(ANYPOINT_PLATFORM_CLIENT_SECRET, clientSecret);
                        }
                    } catch (HttpException e) {
                        if (e.getStatusCode() != 401) {
                            throw e;
                        }
                    }
                }
                if (assetPublished && deploymentRequest.isDeleteSnapshots()) {
                    exchangeManagementClient.deleteSnapshots(organization, applicationDescriptor.getApi().getAsset());
                }
                final ClientApplicationDescriptor clientDescriptor = applicationDescriptor.getClient();
                ClientApplication clientApp = provisioningResult.getClientApplication();
                if (clientApp != null && clientDescriptor != null && clientDescriptor.isInjectClientIdSec()) {
                    final String clientIdProperty = clientDescriptor.getClientIdProperty();
                    if (clientIdProperty == null) {
                        throw new IllegalStateException("client descriptor id property musn't be null");
                    }
                    deploymentRequest.setOverrideProperty(clientIdProperty, clientApp.getClientId());
                    final String clientSecretProperty = clientDescriptor.getClientSecretProperty();
                    if (clientSecretProperty == null) {
                        throw new IllegalStateException("client descriptor id property musn't be null");
                    }
                    deploymentRequest.setSecureOverrideProperty(clientSecretProperty, clientApp.getClientSecret());
                }
            }
//            if (deploymentRequest.isFilePropertiesSecure() && applicationDescriptor != null &&
//                    applicationDescriptor.getProperties() != null) {
//                for (PropertyDescriptor propertyDescriptor : applicationDescriptor.getProperties().values()) {
//                    if (propertyDescriptor.isSecure()) {
//                        String pVal = deploymentRequest.getProperties().remove(propertyDescriptor.getKey());
//                        deploymentRequest.addFileProperty(propertyDescriptor.getKey(), pVal);
//                    }
//                }
//            }
            final Map fileProperties = deploymentRequest.getFileProperties();
            if (fileProperties != null && !fileProperties.isEmpty()) {
                if (logger.isDebugEnabled()) {
                    logger.debug("File properties injected into application: {}", fileProperties);
                    for (Map.Entry entry : fileProperties.entrySet()) {
                        logger.debug("> {} = {}", entry.getKey(), entry.getValue());
                    }
                    logger.debug("filePropertiesPath= {}", deploymentRequest.getFilePropertiesPath());
                }
                transformers.add(new SetPropertyTransformer(deploymentRequest.getFilePropertiesPath(), CREATE,
                        new HashMap<>(fileProperties)));
                logger.info("Added properties file to application archive");
            }
            if (!transformers.isEmpty()) {
                try {
                    if (source instanceof FileApplicationSource || source.getLocalFile() != null) {
                        File oldFile = source.getLocalFile();
                        File newFile = new TempFile("transformed", deploymentRequest.getFilename());
                        source = new FileApplicationSource(client, newFile);
                        Unpacker unpacker = new Unpacker(oldFile, FileType.ZIP, newFile, FileType.ZIP);
                        unpacker.addTransformers(transformers);
                        unpacker.unpack();
                        logger.info("Enhanced application archive");
                    } else if (source instanceof ExchangeApplicationSource) {
                        throw new ProvisioningException("Transformations on exchange sources not supported at this (so OnPrem provisioned deployments won't work with exchange sources until this feature is added)");
                    }
                } catch (Exception e) {
                    throw new ProvisioningException("An error occurred while applying application " + deploymentRequest.getAppName() + " transformations: " + e.getMessage(), e);
                }
                tmpFile = true;
            }
            return doDeploy(deploymentRequest);
        } catch (NotFoundException e) {
            throw new DeploymentException(e);
        } finally {
            if (tmpFile) {
                IOUtils.close((TempFile) source.getLocalFile());
            }
        }
    }

    protected abstract DeploymentResult doDeploy(RuntimeDeploymentRequest request) throws IOException, HttpException, DeploymentException;

    public Environment getEnvironment() {
        return environment;
    }

    public void setEnvironment(Environment environment) {
        this.environment = environment;
    }

    public ApplicationSource getSource() {
        return source;
    }

    public void setSource(ApplicationSource source) {
        this.source = source;
    }

    protected String executeRequest(long start, HttpHelper.MultiPartRequest multiPartRequest) throws HttpException, IOException {
        String json = multiPartRequest.execute();
        if (logger.isDebugEnabled()) {
            logger.debug("File upload took " + TimeUnit.MILLISECONDS.toSeconds(System.currentTimeMillis() - start) + " seconds");
        }
        return json;
    }

    public String processAppName(String appName) {
        return appName != null ? appName : deploymentRequest.getArtifactId();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy