Skip to content

Commit

Permalink
issue-581, handling no external IPs or private cluster for PostgreSQL…
Browse files Browse the repository at this point in the history
… users is implemented
  • Loading branch information
DoodgeMatvey committed Oct 5, 2023
1 parent a3fd665 commit a6f9412
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 2 deletions.
2 changes: 0 additions & 2 deletions controllers/clusterresources/postgresqluser_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -166,8 +166,6 @@ func (r *PostgreSQLUserReconciler) Reconcile(ctx context.Context, req ctrl.Reque
"User has been created for a cluster. Cluster ID: %s, username: %s",
clusterID, newUsername)

// TODO: Add deletion user finalizers

continue
}

Expand Down
56 changes: 56 additions & 0 deletions controllers/clusters/postgresql_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -296,6 +296,62 @@ func (r *PostgreSQLReconciler) handleCreateCluster(
return models.ReconcileRequeue
}

if pg.Spec.UserRefs != nil {
nodeList := &k8sCore.NodeList{}

err = r.List(ctx, nodeList, &client.ListOptions{})
if err != nil {
logger.Error(err, "Cannot list all nodes",
"cluster name", pg.Spec.Name,
"clusterID", pg.Status.ID,
)

r.EventRecorder.Eventf(
pg, models.Warning, models.CreationFailed,
"Fetching all nodes is failed. Reason: %v",
err,
)

return models.ReconcileRequeue
}

var externalIPExists bool
for _, node := range nodeList.Items {
for _, nodeAddress := range node.Status.Addresses {
if nodeAddress.Type == k8sCore.NodeExternalIP {
externalIPExists = true
break
}
}
}

if !externalIPExists || pg.Spec.PrivateNetworkCluster {
logger.Error(err, "Cannot create PostgreSQL user, if your cluster is private or has no external ips "+
"you need to configure peering and remove user references from cluster specification",
"cluster name", pg.Spec.Name,
"clusterID", pg.Status.ID,
)

r.EventRecorder.Eventf(
pg, models.Warning, models.CreationFailed,
"Creating PostgreSQL user has been failed. Reason: %v", err,
)

return models.ReconcileRequeue
}

err = r.startUsersCreationJob(pg)
if err != nil {
logger.Error(err, "Failed to start user PostreSQL creation job")
r.EventRecorder.Eventf(pg, models.Warning, models.CreationFailed,
"User creation job is failed. Reason: %v", err)
return models.ReconcileRequeue
}

r.EventRecorder.Event(pg, models.Normal, models.Created,
"Cluster user creation job is started")
}

return models.ExitReconcile
}

Expand Down

0 comments on commit a6f9412

Please sign in to comment.