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

com.spotify.helios.common.descriptors.DeploymentGroup Maven / Gradle / Ivy

/*
 * Copyright (c) 2015 Spotify AB.
 *
 * 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.
 */

package com.spotify.helios.common.descriptors;

import com.google.common.collect.Lists;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;

import org.jetbrains.annotations.Nullable;

import java.util.List;

import static java.util.Collections.emptyList;

/**
 * Represents a Helios deployment group.
 *
 * An sample expression of it in JSON might be:
 * 
 * {
 *   "name":"foo-group",
 *   "jobId":"foo:0.1.0",
 *   "hostSelectors":[
 *     {
 *       "label":"foo",
 *       "operator":"EQUALS"
 *       "operand":"bar",
 *     },
 *     {
 *       "label":"baz",
 *       "operator":"EQUALS"
 *       "operand":"qux",
 *     }
 *   ],
 *   "rolloutOptions":{
 *     "migrate":false,
 *     "parallelism":2,
 *     "timeout":1000,
 *     "overlap":true,
 *     "token": "insecure-access-token"
 *   },
 *   "rollingUpdateReason": "MANUAL"
 * }
 * 
*/ @JsonIgnoreProperties(ignoreUnknown = true) @JsonInclude(JsonInclude.Include.NON_NULL) public class DeploymentGroup extends Descriptor { public enum RollingUpdateReason { MANUAL, HOSTS_CHANGED } public static final String EMPTY_NAME = ""; public static final JobId EMPTY_JOB_ID = null; private final String name; private final List hostSelectors; private final JobId jobId; private final RolloutOptions rolloutOptions; private final RollingUpdateReason reason; /** * Create a Job. * * Note that despite annotating jobId as @JsonProperty("job") in practice it's serialised as * "jobId" because we neglected to annotate the getter to match. The annotation has been left here * to ensure backwards compatibility. * * @param name The docker name to use. * @param jobId The job ID for the deployment group. * @param hostSelectors The selectors that determine which agents are part of the deployment * group. * @param reason The reason the most recent rolling update (if any) occurred. */ public DeploymentGroup( @JsonProperty("name") final String name, @JsonProperty("hostSelectors") final List hostSelectors, @JsonProperty("job") @Nullable final JobId jobId, @JsonProperty("rolloutOptions") @Nullable final RolloutOptions rolloutOptions, @JsonProperty("rollingUpdateReason") @Nullable final RollingUpdateReason reason) { this.name = name; this.hostSelectors = hostSelectors; this.jobId = jobId; this.rolloutOptions = rolloutOptions; this.reason = reason; } public String getName() { return name; } public JobId getJobId() { return jobId; } public List getHostSelectors() { return hostSelectors; } public RolloutOptions getRolloutOptions() { return rolloutOptions; } public RollingUpdateReason getRollingUpdateReason() { return reason; } public static Builder newBuilder() { return new Builder(); } @Override public boolean equals(final Object o) { if (this == o) { return true; } if (o == null || getClass() != o.getClass()) { return false; } final DeploymentGroup that = (DeploymentGroup) o; if (jobId != null ? !jobId.equals(that.jobId) : that.jobId != null) { return false; } if (hostSelectors != null ? !hostSelectors.equals(that.hostSelectors) : that.hostSelectors != null) { return false; } if (name != null ? !name.equals(that.name) : that.name != null) { return false; } if (rolloutOptions != null ? !rolloutOptions.equals(that.rolloutOptions) : that.rolloutOptions != null) { return false; } if (reason != null ? !reason.equals(that.reason) : that.reason != null) { return false; } return true; } @Override public int hashCode() { int result = name != null ? name.hashCode() : 0; result = 31 * result + (hostSelectors != null ? hostSelectors.hashCode() : 0); result = 31 * result + (jobId != null ? jobId.hashCode() : 0); result = 31 * result + (rolloutOptions != null ? rolloutOptions.hashCode() : 0); result = 31 * result + (reason != null ? reason.hashCode() : 0); return result; } @Override public String toString() { return "DeploymentGroup{" + "name='" + name + '\'' + ", hostSelectors=" + hostSelectors + ", job=" + jobId + ", rolloutOptions=" + rolloutOptions + ", reason=" + reason + '}'; } public Builder toBuilder() { final Builder builder = newBuilder(); return builder.setName(name) .setJobId(jobId) .setHostSelectors(hostSelectors) .setRolloutOptions(rolloutOptions) .setRollingUpdateReason(reason); } public static class Builder implements Cloneable { private final Parameters p; private Builder() { this.p = new Parameters(); } private static class Parameters implements Cloneable { public String name; public JobId jobId; public List hostSelectors; public RolloutOptions rolloutOptions; public RollingUpdateReason reason; private Parameters() { this.name = EMPTY_NAME; this.jobId = EMPTY_JOB_ID; this.hostSelectors = emptyList(); this.rolloutOptions = null; this.reason = null; } } public String getName() { return p.name; } public Builder setName(final String name) { p.name = name; return this; } public JobId getJobId() { return p.jobId; } public Builder setJobId(final JobId jobId) { p.jobId = jobId; return this; } public List getHostSelectors() { return p.hostSelectors; } public Builder setHostSelectors(final List hostSelectors) { p.hostSelectors = Lists.newArrayList(hostSelectors); return this; } public RolloutOptions getRolloutOptions() { return p.rolloutOptions; } public Builder setRolloutOptions(final RolloutOptions rolloutOptions) { p.rolloutOptions = rolloutOptions; return this; } public RollingUpdateReason getRollingUpdateReason() { return p.reason; } public Builder setRollingUpdateReason(final RollingUpdateReason reason) { p.reason = reason; return this; } public DeploymentGroup build() { return new DeploymentGroup(p.name, p.hostSelectors, p.jobId, p.rolloutOptions, p.reason); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy