Git Product home page Git Product logo

lieutenant-keycloak-idp-controller's Introduction

lieutenant-keycloak-idp-controller

Lieutenant Keycloak IDP Controller is a Kubernetes controller that runs in a Lieutenant cluster and manages the creation of Keycloak OIDC clients for every registered cluster.

Getting Started

Youโ€™ll need a Kubernetes cluster to run against. You can use KIND to get a local cluster for testing, or run against a remote cluster. Note: Your controller will automatically use the current context in your kubeconfig file (i.e. whatever cluster kubectl cluster-info shows).

Running on the cluster

  1. Install Instances of Custom Resources:
# install the CRDs into the cluster
kubectl apply -k https://github.com/projectsyn/lieutenant-operator//config/crd

# apply some objects to the cluster to your discretion
kubectl apply -f config/samples/
  1. Build and push your image to the location specified by IMG:
make docker-build docker-push IMG=<some-registry>/lieutenant-keycloak-idp-controller:tag
  1. Deploy the controller to the cluster with the image specified by IMG:
make deploy IMG=<some-registry>/lieutenant-keycloak-idp-controller:tag

Uninstall CRDs

To delete the CRDs from the cluster:

make uninstall

Undeploy controller

UnDeploy the controller from the cluster:

make undeploy

How it works

This project aims to follow the Kubernetes Operator pattern.

It uses Controllers, which provide a reconcile function responsible for synchronizing resources until the desired state is reached on the cluster.

Test It Out

  1. Install the CRDs into the cluster:
make install
  1. Run your controller (this will run in the foreground, so switch to a new terminal if you want to leave it running):
make run

NOTE: You can also run this in one step by running: make install run

Modifying the API definitions

If you are editing the API definitions, generate the manifests such as CRs or CRDs using:

make manifests

NOTE: Run make --help for more information on all potential make targets

More information can be found via the Kubebuilder Documentation

VSHN Development Infrastructure

For a full E2E development setup the VSHN infrastructure has you covered.

  1. Create your isolated realm on the testing Keycloak https://id.test.vshn.net/auth/admin/master/console/#/master/add-realm.
  2. Create a user for the controller in the admin realm https://id.test.vshn.net/auth/admin/master/console/#/master/users/add-user. Configure as follows: User Details User Password User Roles
  3. Sign in to the lieutenant-dev cluster at https://syn-lieutenant-dev.apps.cloudscale-lpg-2.appuio.cloud/.
  4. Run the controller with the following command:
REALM=your-realm-name
KEYCLOAK_USER=your-controller-user
KEYCLOAK_PASSWORD=your-controller-password

make RUN_ARGS="--keycloak-realm=$REALM --keycloak-base-url=https://id.test.vshn.net --keycloak-user=$KEYCLOAK_USER --keycloak-password=$KEYCLOAK_PASSWORD --keycloak-login-realm=master --keycloak-legacy-wildfly-support=true --vault-address=https://vault-dev.syn.vshn.net/ --vault-token=$(kubectl create token -n lieutenant lieutenant-keycloak-idp-controller)" run

lieutenant-keycloak-idp-controller's People

Contributors

bastjan avatar renovate[bot] avatar

Watchers

 avatar  avatar  avatar  avatar  avatar

lieutenant-keycloak-idp-controller's Issues

Dependency Dashboard

This issue lists Renovate updates and detected dependencies. Read the Dependency Dashboard docs to learn more.

Rate-Limited

These updates are currently rate-limited. Click on a checkbox below to force their creation now.

  • Update golang.org/x/exp digest to 7f521ea
  • Update k8s.io/utils digest to fe8a2dd
  • Update docker.io/library/alpine Docker tag to v3.20
  • Update module github.com/Nerzal/gocloak/v13 to v13.9.0
  • Update module github.com/projectsyn/lieutenant-operator to v1.9.1
  • Update module github.com/stretchr/testify to v1.9.0
  • Update module sigs.k8s.io/kustomize/kustomize/v5 to v5.4.2
  • Update goreleaser/goreleaser-action action to v6
  • ๐Ÿ” Create all rate-limited PRs at once ๐Ÿ”

Open

These updates have all been created already. Click a checkbox below to force a retry/rebase of any.

Detected dependencies

dockerfile
Dockerfile
  • docker.io/library/alpine 3.19
github-actions
.github/workflows/build.yml
  • actions/checkout v4
  • actions/setup-go v5
  • actions/cache v3
.github/workflows/lint.yml
  • actions/checkout v4
  • actions/setup-go v5
  • actions/cache v3
.github/workflows/release.yml
  • actions/checkout v4
  • actions/setup-go v5
  • docker/setup-qemu-action v3
  • docker/setup-buildx-action v3
  • actions/cache v3
  • docker/login-action v3
  • mikepenz/release-changelog-builder-action v4
  • goreleaser/goreleaser-action v5
.github/workflows/test.yml
  • actions/checkout v4
  • actions/setup-go v5
  • actions/cache v3
gomod
go.mod
  • go 1.21
  • go 1.21.4
  • github.com/Nerzal/gocloak/v13 v13.8.0
  • github.com/go-logr/logr v1.3.0
  • github.com/google/go-jsonnet v0.20.0
  • github.com/hashicorp/vault-client-go v0.4.2
  • github.com/projectsyn/lieutenant-operator v1.5.0
  • github.com/stretchr/testify v1.8.4
  • github.com/wI2L/jsondiff v0.5.0
  • go.uber.org/mock v0.3.0
  • go.uber.org/multierr v1.11.0
  • golang.org/x/exp v0.0.0-20231127185646-65229373498e@65229373498e
  • golang.org/x/oauth2 v0.15.0
  • k8s.io/apimachinery v0.28.4
  • k8s.io/client-go v0.28.4
  • k8s.io/utils v0.0.0-20231127182322-b307cd553661@b307cd553661
  • sigs.k8s.io/controller-runtime v0.16.3
  • sigs.k8s.io/controller-tools v0.13.0
  • sigs.k8s.io/kustomize/kustomize/v5 v5.3.0

  • Check this box to trigger a request for Renovate to run again on this repository

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.