annotations.io.alauda.kubernetes.api.model.JobStatusFluentImpl Maven / Gradle / Ivy
package io.alauda.kubernetes.api.model;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonInclude;
import io.alauda.kubernetes.api.builder.Nested;
import java.util.ArrayList;
import java.lang.String;
import io.alauda.kubernetes.api.builder.Predicate;
import java.lang.Integer;
import java.lang.Deprecated;
import javax.validation.Valid;
import io.alauda.kubernetes.api.builder.BaseFluent;
import java.util.Collection;
import java.lang.Object;
import java.util.List;
import java.lang.Boolean;
public class JobStatusFluentImpl> extends io.alauda.kubernetes.api.builder.BaseFluent implements JobStatusFluent{
private Integer active;
private String completionTime;
private List conditions = new ArrayList();
private Integer failed;
private String startTime;
private Integer succeeded;
public JobStatusFluentImpl(){
}
public JobStatusFluentImpl(JobStatus instance){
this.withActive(instance.getActive());
this.withCompletionTime(instance.getCompletionTime());
this.withConditions(instance.getConditions());
this.withFailed(instance.getFailed());
this.withStartTime(instance.getStartTime());
this.withSucceeded(instance.getSucceeded());
}
public Integer getActive(){
return this.active;
}
public A withActive(Integer active){
this.active=active; return (A) this;
}
public Boolean hasActive(){
return this.active!=null;
}
public String getCompletionTime(){
return this.completionTime;
}
public A withCompletionTime(String completionTime){
this.completionTime=completionTime; return (A) this;
}
public Boolean hasCompletionTime(){
return this.completionTime!=null;
}
public A addToConditions(int index,JobCondition item){
JobConditionBuilder builder = new JobConditionBuilder(item);_visitables.add(index >= 0 ? index : _visitables.size(), builder);this.conditions.add(index >= 0 ? index : conditions.size(), builder); return (A)this;
}
public A setToConditions(int index,JobCondition item){
JobConditionBuilder builder = new JobConditionBuilder(item);
if (index < 0 || index >= _visitables.size()) { _visitables.add(builder); } else { _visitables.set(index, builder);}
if (index < 0 || index >= conditions.size()) { conditions.add(builder); } else { conditions.set(index, builder);}
return (A)this;
}
public A addToConditions(JobCondition... items){
for (JobCondition item : items) {JobConditionBuilder builder = new JobConditionBuilder(item);_visitables.add(builder);this.conditions.add(builder);} return (A)this;
}
public A addAllToConditions(Collection items){
for (JobCondition item : items) {JobConditionBuilder builder = new JobConditionBuilder(item);_visitables.add(builder);this.conditions.add(builder);} return (A)this;
}
public A removeFromConditions(JobCondition... items){
for (JobCondition item : items) {JobConditionBuilder builder = new JobConditionBuilder(item);_visitables.remove(builder);this.conditions.remove(builder);} return (A)this;
}
public A removeAllFromConditions(Collection items){
for (JobCondition item : items) {JobConditionBuilder builder = new JobConditionBuilder(item);_visitables.remove(builder);this.conditions.remove(builder);} return (A)this;
}
/**
* This method has been deprecated, please use method buildConditions instead.
*/
@Deprecated public List getConditions(){
return build(conditions);
}
public List buildConditions(){
return build(conditions);
}
public JobCondition buildCondition(int index){
return this.conditions.get(index).build();
}
public JobCondition buildFirstCondition(){
return this.conditions.get(0).build();
}
public JobCondition buildLastCondition(){
return this.conditions.get(conditions.size() - 1).build();
}
public JobCondition buildMatchingCondition(io.alauda.kubernetes.api.builder.Predicate predicate){
for (JobConditionBuilder item: conditions) { if(predicate.apply(item)){return item.build();} } return null;
}
public A withConditions(List conditions){
_visitables.removeAll(this.conditions);
this.conditions.clear();
if (conditions != null) {for (JobCondition item : conditions){this.addToConditions(item);}} return (A) this;
}
public A withConditions(JobCondition... conditions){
this.conditions.clear(); if (conditions != null) {for (JobCondition item :conditions){ this.addToConditions(item);}} return (A) this;
}
public Boolean hasConditions(){
return conditions!= null && !conditions.isEmpty();
}
public JobStatusFluent.ConditionsNested addNewCondition(){
return new ConditionsNestedImpl();
}
public JobStatusFluent.ConditionsNested addNewConditionLike(JobCondition item){
return new ConditionsNestedImpl(-1, item);
}
public JobStatusFluent.ConditionsNested setNewConditionLike(int index,JobCondition item){
return new ConditionsNestedImpl(index, item);
}
public JobStatusFluent.ConditionsNested editCondition(int index){
if (conditions.size() <= index) throw new RuntimeException("Can't edit conditions. Index exceeds size.");
return setNewConditionLike(index, buildCondition(index));
}
public JobStatusFluent.ConditionsNested editFirstCondition(){
if (conditions.size() == 0) throw new RuntimeException("Can't edit first conditions. The list is empty.");
return setNewConditionLike(0, buildCondition(0));
}
public JobStatusFluent.ConditionsNested editLastCondition(){
int index = conditions.size() - 1;
if (index < 0) throw new RuntimeException("Can't edit last conditions. The list is empty.");
return setNewConditionLike(index, buildCondition(index));
}
public JobStatusFluent.ConditionsNested editMatchingCondition(io.alauda.kubernetes.api.builder.Predicate predicate){
int index = -1;
for (int i=0;i extends JobConditionFluentImpl> implements JobStatusFluent.ConditionsNested,io.alauda.kubernetes.api.builder.Nested{
private final JobConditionBuilder builder;
private final int index;
ConditionsNestedImpl(int index,JobCondition item){
this.index = index;
this.builder = new JobConditionBuilder(this, item);
}
ConditionsNestedImpl(){
this.index = -1;
this.builder = new JobConditionBuilder(this);
}
public N and(){
return (N) JobStatusFluentImpl.this.setToConditions(index, builder.build());
}
public N endCondition(){
return and();
}
}
}