-
Notifications
You must be signed in to change notification settings - Fork 2.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add nodeSelect capability to kubernetes extension.
Fix #44122 Signed-off-by: Vinche <[email protected]>
- Loading branch information
Showing
16 changed files
with
444 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
15 changes: 15 additions & 0 deletions
15
...vanilla/deployment/src/main/java/io/quarkus/kubernetes/deployment/NodeSelectorConfig.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
package io.quarkus.kubernetes.deployment; | ||
|
||
import java.util.Optional; | ||
|
||
public interface NodeSelectorConfig { | ||
/** | ||
* The key of the nodeSelector. | ||
*/ | ||
Optional<String> key(); | ||
|
||
/** | ||
* The value of the nodeSelector. | ||
*/ | ||
Optional<String> value(); | ||
} |
22 changes: 22 additions & 0 deletions
22
...illa/deployment/src/main/java/io/quarkus/kubernetes/deployment/NodeSelectorConverter.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
package io.quarkus.kubernetes.deployment; | ||
|
||
import io.quarkus.kubernetes.deployment.nodeselector.NodeSelector; | ||
import io.quarkus.kubernetes.deployment.nodeselector.NodeSelectorBuilder; | ||
|
||
public class NodeSelectorConverter { | ||
|
||
public static NodeSelector convert(NodeSelectorConfig nodeSelector) { | ||
return convertToBuilder(nodeSelector).build(); | ||
} | ||
|
||
public static NodeSelectorBuilder convertToBuilder(NodeSelectorConfig nodeSelector) { | ||
NodeSelectorBuilder b = new NodeSelectorBuilder(); | ||
if (nodeSelector.key().isPresent() && nodeSelector.value().isPresent()) { | ||
b.withKey(nodeSelector.key().get()); | ||
b.withValue(nodeSelector.value().get()); | ||
} | ||
|
||
return b; | ||
} | ||
|
||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
45 changes: 45 additions & 0 deletions
45
...src/main/java/io/quarkus/kubernetes/deployment/nodeselector/AddNodeSelectorDecorator.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
package io.quarkus.kubernetes.deployment.nodeselector; | ||
|
||
import java.util.Objects; | ||
|
||
import io.dekorate.kubernetes.decorator.NamedResourceDecorator; | ||
import io.dekorate.utils.Strings; | ||
import io.fabric8.kubernetes.api.model.ObjectMeta; | ||
import io.fabric8.kubernetes.api.model.PodSpecFluent; | ||
|
||
/** | ||
* Copied from dekorate. | ||
* TODO: This decorator should be removed and replaced by the Dekorate AddNodeSelectorDecorator class after | ||
* https://github.com/dekorateio/dekorate/pull/1299 is merged and Dekorate is bumped. | ||
*/ | ||
public class AddNodeSelectorDecorator extends NamedResourceDecorator<PodSpecFluent<?>> { | ||
|
||
private final NodeSelector nodeSelector; | ||
|
||
public AddNodeSelectorDecorator(String deploymentName, NodeSelector nodeSelector) { | ||
super(deploymentName); | ||
this.nodeSelector = nodeSelector; | ||
} | ||
|
||
public void andThenVisit(PodSpecFluent<?> podSpec, ObjectMeta resourceMeta) { | ||
if (Strings.isNotNullOrEmpty(nodeSelector.getKey()) && Strings.isNotNullOrEmpty(nodeSelector.getValue())) { | ||
podSpec.removeFromNodeSelector(nodeSelector.getKey()); | ||
podSpec.addToNodeSelector(nodeSelector.getKey(), nodeSelector.getValue()); | ||
} | ||
} | ||
|
||
@Override | ||
public boolean equals(Object o) { | ||
if (this == o) | ||
return true; | ||
if (o == null || getClass() != o.getClass()) | ||
return false; | ||
AddNodeSelectorDecorator that = (AddNodeSelectorDecorator) o; | ||
return Objects.equals(nodeSelector, that.nodeSelector); | ||
} | ||
|
||
@Override | ||
public int hashCode() { | ||
return Objects.hash(nodeSelector); | ||
} | ||
} |
58 changes: 58 additions & 0 deletions
58
...ava/io/quarkus/kubernetes/deployment/nodeselector/AddNodeSelectorToRevisionDecorator.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
package io.quarkus.kubernetes.deployment.nodeselector; | ||
|
||
import java.util.HashMap; | ||
import java.util.Map; | ||
import java.util.Objects; | ||
|
||
import io.dekorate.kubernetes.decorator.NamedResourceDecorator; | ||
import io.dekorate.utils.Strings; | ||
import io.fabric8.knative.serving.v1.RevisionSpecFluent; | ||
import io.fabric8.kubernetes.api.model.ObjectMeta; | ||
|
||
/** | ||
* Copied from dekorate. | ||
* TODO: This decorator should be removed and replaced by the Dekorate AddNodeSelectorToRevisionDecorator class after | ||
* https://github.com/dekorateio/dekorate/pull/1299 is merged and Dekorate is bumped. | ||
*/ | ||
public class AddNodeSelectorToRevisionDecorator extends NamedResourceDecorator<RevisionSpecFluent<?>> { | ||
|
||
private final NodeSelector nodeSelector; | ||
|
||
public AddNodeSelectorToRevisionDecorator(NodeSelector nodeSelector) { | ||
this(ANY, nodeSelector); | ||
} | ||
|
||
public AddNodeSelectorToRevisionDecorator(String deploymentName, NodeSelector nodeSelector) { | ||
super(deploymentName); | ||
this.nodeSelector = nodeSelector; | ||
} | ||
|
||
public void andThenVisit(RevisionSpecFluent<?> revisionSpec, ObjectMeta resourceMeta) { | ||
if (Strings.isNotNullOrEmpty(nodeSelector.getKey()) && Strings.isNotNullOrEmpty(nodeSelector.getValue())) { | ||
Map<String, String> existing = revisionSpec.getNodeSelector(); | ||
|
||
if (existing == null) | ||
existing = new HashMap<>(); | ||
else | ||
existing.clear(); | ||
|
||
existing.put(nodeSelector.getKey(), nodeSelector.getValue()); | ||
revisionSpec.withNodeSelector(existing); | ||
} | ||
} | ||
|
||
@Override | ||
public boolean equals(Object o) { | ||
if (this == o) | ||
return true; | ||
if (o == null || getClass() != o.getClass()) | ||
return false; | ||
AddNodeSelectorToRevisionDecorator that = (AddNodeSelectorToRevisionDecorator) o; | ||
return Objects.equals(nodeSelector, that.nodeSelector); | ||
} | ||
|
||
@Override | ||
public int hashCode() { | ||
return Objects.hash(nodeSelector); | ||
} | ||
} |
23 changes: 23 additions & 0 deletions
23
...ent/src/main/java/io/quarkus/kubernetes/deployment/nodeselector/EditableNodeSelector.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
package io.quarkus.kubernetes.deployment.nodeselector; | ||
|
||
import io.fabric8.kubernetes.api.builder.Editable; | ||
|
||
/** | ||
* Copied from dekorate. | ||
* TODO: This should be removed and replaced after | ||
* https://github.com/dekorateio/dekorate/pull/1299 is merged and Dekorate is bumped. | ||
*/ | ||
public class EditableNodeSelector extends NodeSelector implements Editable<NodeSelectorBuilder> { | ||
public EditableNodeSelector() { | ||
super(); | ||
} | ||
|
||
public EditableNodeSelector(String key, String value) { | ||
super(key, value); | ||
} | ||
|
||
public NodeSelectorBuilder edit() { | ||
return new NodeSelectorBuilder(this); | ||
} | ||
|
||
} |
57 changes: 57 additions & 0 deletions
57
.../deployment/src/main/java/io/quarkus/kubernetes/deployment/nodeselector/NodeSelector.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
package io.quarkus.kubernetes.deployment.nodeselector; | ||
|
||
import io.fabric8.kubernetes.api.model.NodeSelectorBuilder; | ||
|
||
/** | ||
* Copied from dekorate. | ||
* TODO: This should be removed and replaced after | ||
* https://github.com/dekorateio/dekorate/pull/1299 is merged and Dekorate is bumped. | ||
*/ | ||
public class NodeSelector { | ||
private String key; | ||
private String value; | ||
|
||
public NodeSelector() { | ||
} | ||
|
||
public NodeSelector(String key, String value) { | ||
this.key = key; | ||
this.value = value; | ||
} | ||
|
||
public String getKey() { | ||
return this.key; | ||
} | ||
|
||
public String getValue() { | ||
return this.value; | ||
} | ||
|
||
public static NodeSelectorBuilder newBuilder() { | ||
return new NodeSelectorBuilder(); | ||
} | ||
|
||
public static NodeSelectorBuilder newBuilderFromDefaults() { | ||
return new NodeSelectorBuilder(); | ||
} | ||
|
||
public boolean equals(Object o) { | ||
if (this == o) | ||
return true; | ||
if (o == null || getClass() != o.getClass()) | ||
return false; | ||
if (!super.equals(o)) | ||
return false; | ||
NodeSelector that = (NodeSelector) o; | ||
if (!java.util.Objects.equals(key, that.key)) | ||
return false; | ||
if (!java.util.Objects.equals(value, that.value)) | ||
return false; | ||
return true; | ||
} | ||
|
||
public int hashCode() { | ||
return java.util.Objects.hash(key, value, super.hashCode()); | ||
} | ||
|
||
} |
37 changes: 37 additions & 0 deletions
37
...ment/src/main/java/io/quarkus/kubernetes/deployment/nodeselector/NodeSelectorBuilder.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
package io.quarkus.kubernetes.deployment.nodeselector; | ||
|
||
import io.fabric8.kubernetes.api.builder.VisitableBuilder; | ||
|
||
/** | ||
* Copied from dekorate. | ||
* TODO: This should be removed and replaced after | ||
* https://github.com/dekorateio/dekorate/pull/1299 is merged and Dekorate is bumped. | ||
*/ | ||
public class NodeSelectorBuilder extends NodeSelectorFluent<NodeSelectorBuilder> | ||
implements VisitableBuilder<NodeSelector, NodeSelectorBuilder> { | ||
|
||
public NodeSelectorBuilder() { | ||
this(new NodeSelector()); | ||
} | ||
|
||
public NodeSelectorBuilder(NodeSelectorFluent<?> fluent) { | ||
this(fluent, new NodeSelector()); | ||
} | ||
|
||
public NodeSelectorBuilder(NodeSelectorFluent<?> fluent, NodeSelector instance) { | ||
this.fluent = fluent; | ||
fluent.copyInstance(instance); | ||
} | ||
|
||
public NodeSelectorBuilder(NodeSelector instance) { | ||
this.fluent = this; | ||
this.copyInstance(instance); | ||
} | ||
|
||
NodeSelectorFluent<?> fluent; | ||
|
||
public EditableNodeSelector build() { | ||
EditableNodeSelector buildable = new EditableNodeSelector(fluent.getKey(), fluent.getValue()); | ||
return buildable; | ||
} | ||
} |
Oops, something went wrong.