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

com.openshift.internal.restclient.model.BuildConfig Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 * Copyright (c) 2015-2018 Red Hat, Inc. Distributed under license by Red Hat, Inc.
 * All rights reserved. This program is made available under the terms of the
 * Eclipse Public License v1.0 which accompanies this distribution, and is
 * available at http://www.eclipse.org/legal/epl-v10.html
 * 
 * Contributors: Red Hat, Inc.
 ******************************************************************************/

package com.openshift.internal.restclient.model;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

import org.apache.commons.lang.StringUtils;
import org.jboss.dmr.ModelNode;

import com.openshift.internal.restclient.capability.CapabilityInitializer;
import com.openshift.internal.restclient.model.build.BinaryBuildSource;
import com.openshift.internal.restclient.model.build.CustomBuildStrategy;
import com.openshift.internal.restclient.model.build.DockerBuildStrategy;
import com.openshift.internal.restclient.model.build.GitBuildSource;
import com.openshift.internal.restclient.model.build.ImageChangeTrigger;
import com.openshift.internal.restclient.model.build.JenkinsPipelineStrategy;
import com.openshift.internal.restclient.model.build.SourceBuildStrategy;
import com.openshift.internal.restclient.model.build.WebhookTrigger;
import com.openshift.restclient.IClient;
import com.openshift.restclient.model.IBuildConfig;
import com.openshift.restclient.model.IObjectReference;
import com.openshift.restclient.model.build.BuildSourceType;
import com.openshift.restclient.model.build.BuildStrategyType;
import com.openshift.restclient.model.build.BuildTriggerType;
import com.openshift.restclient.model.build.IBinaryBuildSource;
import com.openshift.restclient.model.build.IBuildSource;
import com.openshift.restclient.model.build.IBuildStrategy;
import com.openshift.restclient.model.build.IBuildTrigger;
import com.openshift.restclient.model.build.ICustomBuildStrategy;
import com.openshift.restclient.model.build.IDockerBuildStrategy;
import com.openshift.restclient.model.build.IGitBuildSource;
import com.openshift.restclient.model.build.IImageChangeTrigger;
import com.openshift.restclient.model.build.IJenkinsPipelineStrategy;
import com.openshift.restclient.model.build.ISourceBuildStrategy;
import com.openshift.restclient.model.build.IWebhookTrigger;

public class BuildConfig extends KubernetesResource implements IBuildConfig {

    public static final String BUILDCONFIG_SOURCE_CONTEXTDIR = "spec.source.contextDir";
    public static final String BUILDCONFIG_SOURCE_TYPE = "spec.source.type";
    public static final String BUILDCONFIG_SOURCE_URI = "spec.source.git.uri";
    public static final String BUILDCONFIG_SOURCE_REF = "spec.source.git.ref";
    public static final String BUILDCONFIG_SOURCE_BINARY_ASFILE = "spec.source.binary.asFile";

    public static final String BUILDCONFIG_TYPE = "spec.strategy.type";
    private static final String BUILDCONFIG_CUSTOM_IMAGE = "spec.strategy.customStrategy.image";
    private static final String BUILDCONFIG_CUSTOM_EXPOSEDOCKERSOCKET = "spec.strategy.customStrategy.exposeDockerSocket";
    private static final String BUILDCONFIG_CUSTOM_ENV = "spec.strategy.customStrategy.env";
    public static final String BUILDCONFIG_DOCKER_CONTEXTDIR = "spec.strategy.dockerStrategy.contextDir";
    public static final String BUILDCONFIG_DOCKER_NOCACHE = "spec.strategy.dockerStrategy.noCache";
    public static final String BUILDCONFIG_DOCKER_BASEIMAGE = "spec.strategy.dockerStrategy.baseImage";
    private static final String BUILDCONFIG_OUTPUT_REPO = "spec.output.to.name";
    private static final String BUILDCONFIG_TRIGGERS = "spec.triggers";
    private static final String BUILDCONFIG_STRATEGY = "spec.strategy";
    private static final String BUILD_CONFIG_WEBHOOK_GITHUB_SECRET = "github.secret";
    private static final String BUILD_CONFIG_WEBHOOK_GENERIC_SECRET = "generic.secret";
    private static final String BUILD_CONFIG_IMAGECHANGE_IMAGE = "imageChange.image";
    private static final String BUILD_CONFIG_IMAGECHANGE_NAME = "imageChange.from.name";
    private static final String BUILD_CONFIG_IMAGECHANGE_TAG = "imageChange.tag";

    public BuildConfig(ModelNode node, IClient client, Map overrideProperties) {
        super(node, client, null);
        CapabilityInitializer.initializeCapabilities(getModifiableCapabilities(), this, client);
    }

    @Override
    public IObjectReference getBuildOutputReference() {
        return new ObjectReference(get("spec.output.to"));
    }

    @Override
    public List getBuildTriggers() {
        List triggers = new ArrayList<>();
        if (has(BUILDCONFIG_TRIGGERS)) {
            List list = get(BUILDCONFIG_TRIGGERS).asList();
            final String url = getClient() != null && StringUtils.isNotEmpty(getNamespaceName())
                    ? getClient().getResourceURI(this)
                    : "";
            for (ModelNode node : list) {
                String type = node.get(TYPE).asString();
                switch (type) {
                case BuildTriggerType.GENERIC:
                    triggers.add(new WebhookTrigger(BuildTriggerType.GENERIC,
                            asString(node, BUILD_CONFIG_WEBHOOK_GENERIC_SECRET), url));
                    break;
                case BuildTriggerType.GITHUB:
                    triggers.add(new WebhookTrigger(BuildTriggerType.GITHUB,
                            asString(node, BUILD_CONFIG_WEBHOOK_GITHUB_SECRET), url));
                    break;
                case BuildTriggerType.IMAGE_CHANGE:
                    triggers.add(new ImageChangeTrigger(BuildTriggerType.IMAGE_CHANGE,
                            asString(node, BUILD_CONFIG_IMAGECHANGE_IMAGE),
                            asString(node, BUILD_CONFIG_IMAGECHANGE_NAME),
                            asString(node, BUILD_CONFIG_IMAGECHANGE_TAG)));
                    break;
                case BuildTriggerType.CONFIG_CHANGE:
                    triggers.add(new ImageChangeTrigger(BuildTriggerType.CONFIG_CHANGE, null, null));
                    break;
                default:
                }
            }
        }
        return triggers;
    }

    @Override
    public void addBuildTrigger(IBuildTrigger trigger) {
        ModelNode triggers = get(BUILDCONFIG_TRIGGERS);
        ModelNode triggerNode = triggers.add();
        switch (trigger.getType()) {
        case BuildTriggerType.GENERIC:
            if (!(trigger instanceof IWebhookTrigger)) {
                throw new IllegalArgumentException("IBuildTrigger of type generic does not implement IWebhookTrigger");
            }
            IWebhookTrigger generic = (IWebhookTrigger) trigger;
            triggerNode.get(getPath(BUILD_CONFIG_WEBHOOK_GENERIC_SECRET)).set(generic.getSecret());
            break;
        case BuildTriggerType.GITHUB:
            if (!(trigger instanceof IWebhookTrigger)) {
                throw new IllegalArgumentException("IBuildTrigger of type github does not implement IWebhookTrigger");
            }
            IWebhookTrigger github = (IWebhookTrigger) trigger;
            triggerNode.get(getPath(BUILD_CONFIG_WEBHOOK_GITHUB_SECRET)).set(github.getSecret());
            break;
        case BuildTriggerType.IMAGE_CHANGE: {
            if (!(trigger instanceof IImageChangeTrigger)) {
                throw new IllegalArgumentException(
                        "IBuildTrigger of type imageChange does not implement IImageChangeTrigger");
            }
            IImageChangeTrigger image = (IImageChangeTrigger) trigger;
            if (image.getImage() != null) {
                triggerNode.get(getPath(BUILD_CONFIG_IMAGECHANGE_IMAGE)).set(image.getImage().toString());
            }
            if (image.getFrom() != null) {
                triggerNode.get(getPath(BUILD_CONFIG_IMAGECHANGE_NAME)).set(image.getFrom().toString());
            }
            if (StringUtils.isNotEmpty(image.getTag())) {
                triggerNode.get(getPath(BUILD_CONFIG_IMAGECHANGE_TAG))
                        .set(StringUtils.defaultIfBlank(image.getTag(), ""));
            }
            break;

        }
        }
        triggerNode.get(TYPE).set(trigger.getType());
    }

    @Override
    public String getOutputRepositoryName() {
        return asString(BUILDCONFIG_OUTPUT_REPO);
    }

    public String getSourceURI() {
        return asString(BUILDCONFIG_SOURCE_URI);
    }

    @SuppressWarnings("unchecked")
    @Override
    public  T getBuildSource() {
        switch (asString(BUILDCONFIG_SOURCE_TYPE)) {
        case BuildSourceType.GIT:
            return (T) new GitBuildSource(asString(BUILDCONFIG_SOURCE_URI), asString(BUILDCONFIG_SOURCE_REF),
                    asString(BUILDCONFIG_SOURCE_CONTEXTDIR));
        case BuildSourceType.BINARY:
            return (T) new BinaryBuildSource(asString(BUILDCONFIG_SOURCE_BINARY_ASFILE), asString(BUILDCONFIG_SOURCE_CONTEXTDIR));
        default:
        }
        return null;
    }

    @Override
    public void setBuildSource(IBuildSource source) {
        switch (source.getType()) {
        case BuildSourceType.GIT:
            if (!(source instanceof IGitBuildSource)) {
                throw new IllegalArgumentException("IBuildSource of type Git does not implement IGitBuildSource");
            }
            IGitBuildSource git = (IGitBuildSource) source;
            set(BUILDCONFIG_SOURCE_REF, git.getRef());
            set(BUILDCONFIG_SOURCE_URI, git.getURI());
            break;
        case BuildSourceType.BINARY:
            if (!(source instanceof IBinaryBuildSource)) {
                throw new IllegalArgumentException("IBuildSource of type Binary does not implement IBinaryBuildSource");
            }
            IBinaryBuildSource binary = (IBinaryBuildSource) source;
            set(BUILDCONFIG_SOURCE_BINARY_ASFILE, binary.getAsFile());
            break;
        }
        set(BUILDCONFIG_SOURCE_TYPE, source.getType());
        set(BUILDCONFIG_SOURCE_CONTEXTDIR, source.getContextDir());
    }

    @Override
    public void setBuildStrategy(IBuildStrategy strategy) {
        // Remove other strategies if already set?
        switch (strategy.getType()) {
        case BuildStrategyType.CUSTOM:
            if (!(strategy instanceof ICustomBuildStrategy)) {
                throw new IllegalArgumentException(
                        "IBuildStrategy of type Custom does not implement ICustomBuildStrategy");
            }
            ICustomBuildStrategy custom = (ICustomBuildStrategy) strategy;
            if (custom.getImage() != null) {
                set(BUILDCONFIG_CUSTOM_IMAGE, custom.getImage().toString());
            }
            set(BUILDCONFIG_CUSTOM_EXPOSEDOCKERSOCKET, custom.exposeDockerSocket());
            if (custom.getEnvironmentVariables() != null) {
                setEnvMap(BUILDCONFIG_CUSTOM_ENV, custom.getEnvironmentVariables());
            }
            break;
        case BuildStrategyType.SOURCE:
            ISourceBuildStrategy source = (ISourceBuildStrategy) strategy;
            get(BUILDCONFIG_STRATEGY).set(ModelNode.fromJSONString(source.toString()));
            break;
        case BuildStrategyType.DOCKER:
            if (!(strategy instanceof IDockerBuildStrategy)) {
                throw new IllegalArgumentException(
                        "IBuildStrategy of type Custom does not implement IDockerBuildStrategy");
            }
            IDockerBuildStrategy docker = (IDockerBuildStrategy) strategy;
            if (docker.getBaseImage() != null) {
                set(BUILDCONFIG_DOCKER_BASEIMAGE, docker.getBaseImage().toString());
            }
            if (docker.getContextDir() != null) {
                set(BUILDCONFIG_DOCKER_CONTEXTDIR, docker.getContextDir());
            }
            set(BUILDCONFIG_DOCKER_NOCACHE, docker.isNoCache());
            break;
        case BuildStrategyType.JENKINS_PIPELINE:
            if (!(strategy instanceof IJenkinsPipelineStrategy)) {
                throw new IllegalArgumentException(
                        "IBuildStrategy of type Custom does not implement IJenkinsPipelineStrategy");
            }
            IJenkinsPipelineStrategy jenkins = (IJenkinsPipelineStrategy) strategy;
            get(BUILDCONFIG_STRATEGY).set(ModelNode.fromJSONString(jenkins.toString()));
            break;
        }

        set(BUILDCONFIG_TYPE, strategy.getType());
    }

    @SuppressWarnings("unchecked")
    @Override
    public  T getBuildStrategy() {
        switch (asString(BUILDCONFIG_TYPE)) {

        case BuildStrategyType.CUSTOM:
            return (T) new CustomBuildStrategy(asString(BUILDCONFIG_CUSTOM_IMAGE),
                    asBoolean(BUILDCONFIG_CUSTOM_EXPOSEDOCKERSOCKET), getEnvMap(BUILDCONFIG_CUSTOM_ENV));
        case BuildStrategyType.SOURCE:
            return (T) new SourceBuildStrategy(get(BUILDCONFIG_STRATEGY), getPropertyKeys());

        case BuildStrategyType.DOCKER:
            return (T) new DockerBuildStrategy(asString(BUILDCONFIG_DOCKER_CONTEXTDIR),
                    asBoolean(BUILDCONFIG_DOCKER_NOCACHE), asString(BUILDCONFIG_DOCKER_BASEIMAGE));

        case BuildStrategyType.JENKINS_PIPELINE:
            return (T) new JenkinsPipelineStrategy(get(BUILDCONFIG_STRATEGY), getPropertyKeys());

        default:
        }
        return null;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy