Skip to content

Commit

Permalink
Deploy container image
Browse files Browse the repository at this point in the history
  • Loading branch information
SupremeMortal committed Jan 18, 2025
1 parent b192f66 commit bee5a17
Show file tree
Hide file tree
Showing 6 changed files with 128 additions and 64 deletions.
18 changes: 18 additions & 0 deletions .github/workflows/deploy.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
on:
push:
branches:
- master

jobs:
deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout Repository
uses: actions/checkout@v4
- name: Java Setup
uses: actions/setup-java@v4
with:
distribution: 'graalvm'
java-version: '21'
- name: Gradle Build
run: ./gradlew build -Dquarkus.package.jar.enabled=false -Dquarkus.native.container-build=true -Dquarkus.native.enabled=true -Dquarkus.container-image.build=true -Dquarkus.container-image.push=true -Dquarkus.container-image.username="${{ secrets.QUAY_UN }}" -Dquarkus.container-image.password="${{ secrets.QUAY_PW }}"
6 changes: 4 additions & 2 deletions build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,13 @@ java {
dependencies {
implementation(enforcedPlatform(libs.quarkus.bom))
implementation("io.quarkus:quarkus-arc")
implementation("io.quarkus:quarkus-openshift")
implementation("io.quarkus:quarkus-kubernetes")
implementation("io.quarkus:quarkus-container-image-jib")
implementation("io.quarkus:quarkus-openshift-client")
implementation("io.quarkus:quarkus-scheduler")
implementation("io.quarkus:quarkus-jackson")
implementation("org.eclipse.jgit:org.eclipse.jgit:7.1.0.202411261347-r")
implementation("io.quarkus:quarkus-smallrye-health")
implementation("io.quarkiverse.jgit:quarkus-jgit:3.3.3")

// Lombok
val lombok = "org.projectlombok:lombok:1.18.36"
Expand Down
117 changes: 61 additions & 56 deletions src/main/java/io/okd/operators/controller/Controller.java
Original file line number Diff line number Diff line change
Expand Up @@ -37,20 +37,18 @@ public class Controller {

private static final Path RECIPE_REPO = Paths.get("/tmp", "okd-build-controller", "repo");
private static final JsonMapper MAPPER = new JsonMapper();
// private final Thread watchThread;
private final AtomicBoolean running = new AtomicBoolean(false);
// private final String recipesDirectory;

@Inject
ManagedExecutor managedExecutor;

@Inject
OpenShiftClient client;

@Inject
@ConfigProperty(name = "controller.build-repo")
@ConfigProperty(name = "controller.build-repo", defaultValue = "https://github.com/okd-project/okd-operator-pipeline.git")
String buildRepo;

@Inject
@ConfigProperty(name = "controller.build-branch", defaultValue = "master")
String buildBranch;

@Inject
@ConfigProperty(name = "controller.recipes.directory", defaultValue = "recipes")
String recipesDirectory;
Expand All @@ -71,6 +69,7 @@ void cloneRepo() throws IOException, GitAPIException {
Git.cloneRepository()
.setURI(this.buildRepo)
.setDirectory(RECIPE_REPO.toFile())
.setBranch(this.buildBranch)
.call()
.close();
}
Expand Down Expand Up @@ -287,69 +286,75 @@ private boolean processComponent(Git git, String recipe, String version, Compone

Path gitDirectory = dataDirectory.resolve("git");

Git componentGit;
if (!RepositoryCache.FileKey.isGitRepository(gitDirectory.toFile(), FS.DETECTED)) {
if (Files.exists(gitDirectory)) {
Git componentGit = null;
try {
if (!RepositoryCache.FileKey.isGitRepository(gitDirectory.toFile(), FS.DETECTED)) {
if (Files.exists(gitDirectory)) {
try {
Files.delete(gitDirectory);
} catch (IOException e) {
throw new IllegalStateException("Failed to delete git directory", e);
}
}
try {
Files.delete(gitDirectory);
} catch (IOException e) {
throw new IllegalStateException("Failed to delete git directory", e);
componentGit = Git.cloneRepository()
.setURI(component.getGitUrl())
.setDirectory(gitDirectory.toFile())
.setBranch(branch)
.call();
} catch (GitAPIException e) {
throw new IllegalStateException("Failed to clone repository", e);
}
}
try {
componentGit = Git.cloneRepository()
.setURI(component.getGitUrl())
.setDirectory(gitDirectory.toFile())
.setBranch(branch)
.call();
} catch (GitAPIException e) {
throw new IllegalStateException("Failed to clone repository", e);
}
} else {
try {
componentGit = Git.open(gitDirectory.toFile());
} else {
try {
componentGit = Git.open(gitDirectory.toFile());

componentGit.pull().call();
} catch (IOException | GitAPIException e) {
throw new IllegalStateException("Failed to open git directory", e);
componentGit.pull().call();
} catch (IOException | GitAPIException e) {
throw new IllegalStateException("Failed to open git directory", e);
}
}
}

// Check if we need to create a new PipelineRun by polling the git repo
String hash = null;
boolean runPipeline = false;
try {
List<Ref> call = componentGit.branchList().setListMode(ListBranchCommand.ListMode.REMOTE).call();
log.info("Branches: {}", call.stream().map(Ref::getName).toList());
for (Ref ref : call) {
if (ref.getName().equals("refs/remotes/origin/" + branch)) {
hash = ref.getObjectId().getName();
break;
// Check if we need to create a new PipelineRun by polling the git repo
String hash = null;
boolean runPipeline = false;
try {
List<Ref> call = componentGit.branchList().setListMode(ListBranchCommand.ListMode.REMOTE).call();
log.info("Branches: {}", call.stream().map(Ref::getName).toList());
for (Ref ref : call) {
if (ref.getName().equals("refs/remotes/origin/" + branch)) {
hash = ref.getObjectId().getName();
break;
}
}
}

if (hash == null) {
log.error("Branch {} not found", branch);
throw new IllegalStateException("Branch not found");
}
if (hash == null) {
log.error("Branch {} not found", branch);
throw new IllegalStateException("Branch not found");
}

Path hashFile = dataDirectory.resolve("hash");
Path hashFile = dataDirectory.resolve("hash");

if (Files.notExists(hashFile)) {
Files.writeString(hashFile, hash);
runPipeline = true;
} else {
String existingHash = Files.readString(hashFile);
if (!existingHash.equals(hash)) {
if (Files.notExists(hashFile)) {
Files.writeString(hashFile, hash);
runPipeline = true;
} else {
String existingHash = Files.readString(hashFile);
if (!existingHash.equals(hash)) {
Files.writeString(hashFile, hash);
runPipeline = true;
}
}
} catch (GitAPIException | IOException e) {
throw new IllegalStateException("Failed to get branch list", e);
}
} catch (GitAPIException | IOException e) {
throw new IllegalStateException("Failed to get branch list", e);
}

return runPipeline;
return runPipeline;
} finally {
if (componentGit != null) {
componentGit.close();
}
}
}

private void buildComponent(String recipe, String version, ComponentRecipe component, String buildVersion,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
import io.fabric8.kubernetes.api.model.HasMetadata;
import io.fabric8.kubernetes.api.model.Namespaced;
import io.fabric8.kubernetes.api.model.ObjectMeta;
import io.fabric8.kubernetes.api.model.apps.Deployment;
import io.fabric8.kubernetes.client.CustomResource;
import io.fabric8.kubernetes.model.annotation.Group;
import io.fabric8.kubernetes.model.annotation.Plural;
Expand All @@ -25,7 +26,7 @@
@Group("tekton.dev")
@Singular("pipelinerun")
@Plural("pipelineruns")
public class PipelineRun extends CustomResource<Void, Void> implements Namespaced, HasMetadata {
public class PipelineRun implements Namespaced, HasMetadata {

@JsonProperty("apiVersion")
private String apiVersion = "tekton.dev/v1";
Expand Down
43 changes: 43 additions & 0 deletions src/main/resources/application.properties
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
quarkus.application.name=operator-build-controller
quarkus.application.ui-header=Operator Build Controller

quarkus.analytics.disabled=true
quarkus.log.file.enable=false
quarkus.banner.enabled=false

quarkus.container-image.registry=quay.io
quarkus.container-image.group=okderators
quarkus.container-image.tag=latest

quarkus.kubernetes.idempotent=true
quarkus.kubernetes.vcs-uri.enabled=false
quarkus.kubernetes.deployment-target=openshift
quarkus.kubernetes.part-of=operator-build-controller

quarkus.kubernetes.readiness-probe.initial-delay=20s
quarkus.kubernetes.readiness-probe.period=45s

quarkus.kubernetes.resources.requests.memory=256Mi
quarkus.kubernetes.resources.requests.cpu=250m
quarkus.kubernetes.resources.limits.memory=512Mi
quarkus.kubernetes.resources.limits.cpu=1000m

# Generate Role resource with name "operator-builder"
quarkus.kubernetes.rbac.roles."operator-builder".policy-rules.0.api-groups=extensions,apps,tekton.dev
quarkus.kubernetes.rbac.roles."operator-builder".policy-rules.0.resources=configmaps,pipelineruns
quarkus.kubernetes.rbac.roles."operator-builder".policy-rules.0.verbs=get,watch,list,create,patch,update,delete

# Generate ServiceAccount
quarkus.kubernetes.rbac.service-accounts."operator-build-controller".namespace=okd-operator-build

# Bind Role "operator-builder" with ServiceAccount "operator-build-controller"
quarkus.kubernetes.rbac.role-bindings."operator-builder-binding".subjects."operator-build-controller".kind=ServiceAccount
quarkus.kubernetes.rbac.role-bindings."operator-builder-binding".subjects."operator-build-controller".namespace=okd-operator-build
quarkus.kubernetes.rbac.role-bindings."operator-builder-binding".role-name=operator-builder

controller.name=${CONTROLLER_NAME:operator-build-controller}
controller.build-repo=${BUILD_REPO:https://github.com/okd-project/okd-operator-pipelines.git}
controller.build-branch=${BUILD_BRANCH:master}
controller.recipes.directory=${RECIPES_DIR:recipes}
controller.recipes.patches-directory=${PATCHES_DIR:patches}
controller.data-directory=${DATA_DIR:/opt/okd/recipes}
5 changes: 0 additions & 5 deletions src/main/resources/applications.properties

This file was deleted.

0 comments on commit bee5a17

Please sign in to comment.