mirror of
https://github.com/cloudnative-pg/plugin-barman-cloud.git
synced 2026-01-12 13:43:10 +01:00
Closes #253 Signed-off-by: MichaluxPL <68371308+MichaluxPL@users.noreply.github.com> Signed-off-by: Leonardo Cecchi <leonardo.cecchi@enterprisedb.com> Signed-off-by: Marco Nenciarini <marco.nenciarini@enterprisedb.com> Signed-off-by: Francesco Canovai <francesco.canovai@enterprisedb.com> Co-authored-by: MichaluxPL <68371308+MichaluxPL@users.noreply.github.com> Co-authored-by: Marco Nenciarini <marco.nenciarini@enterprisedb.com> Co-authored-by: Francesco Canovai <francesco.canovai@enterprisedb.com>
62 lines
2.1 KiB
Go
62 lines
2.1 KiB
Go
package operator
|
|
|
|
import (
|
|
"context"
|
|
|
|
corev1 "k8s.io/api/core/v1"
|
|
|
|
barmancloudv1 "github.com/cloudnative-pg/plugin-barman-cloud/api/v1"
|
|
"github.com/cloudnative-pg/plugin-barman-cloud/internal/cnpgi/operator/config"
|
|
)
|
|
|
|
func (impl LifecycleImplementation) collectSidecarResourcesForRecoveryJob(
|
|
ctx context.Context,
|
|
configuration *config.PluginConfiguration,
|
|
) (corev1.ResourceRequirements, error) {
|
|
if len(configuration.RecoveryBarmanObjectName) > 0 {
|
|
var barmanObjectStore barmancloudv1.ObjectStore
|
|
if err := impl.Client.Get(ctx, configuration.GetRecoveryBarmanObjectKey(), &barmanObjectStore); err != nil {
|
|
return corev1.ResourceRequirements{}, err
|
|
}
|
|
|
|
return barmanObjectStore.Spec.InstanceSidecarConfiguration.Resources, nil
|
|
}
|
|
|
|
return corev1.ResourceRequirements{}, nil
|
|
}
|
|
|
|
func (impl LifecycleImplementation) collectSidecarResourcesForPod(
|
|
ctx context.Context,
|
|
configuration *config.PluginConfiguration,
|
|
) (corev1.ResourceRequirements, error) {
|
|
if len(configuration.BarmanObjectName) > 0 {
|
|
// On a replica cluster that also archives, the designated primary
|
|
// will use both the replica source object store and the object store
|
|
// of the cluster.
|
|
// In this case, we use the cluster object store for configuring
|
|
// the resources of the sidecar container.
|
|
|
|
var barmanObjectStore barmancloudv1.ObjectStore
|
|
if err := impl.Client.Get(ctx, configuration.GetBarmanObjectKey(), &barmanObjectStore); err != nil {
|
|
return corev1.ResourceRequirements{}, err
|
|
}
|
|
|
|
return barmanObjectStore.Spec.InstanceSidecarConfiguration.Resources, nil
|
|
}
|
|
|
|
if len(configuration.RecoveryBarmanObjectName) > 0 {
|
|
// On a replica cluster that doesn't archive, the designated primary
|
|
// uses only the replica source object store.
|
|
// In this case, we use the replica source object store for configuring
|
|
// the resources of the sidecar container.
|
|
var barmanObjectStore barmancloudv1.ObjectStore
|
|
if err := impl.Client.Get(ctx, configuration.GetRecoveryBarmanObjectKey(), &barmanObjectStore); err != nil {
|
|
return corev1.ResourceRequirements{}, err
|
|
}
|
|
|
|
return barmanObjectStore.Spec.InstanceSidecarConfiguration.Resources, nil
|
|
}
|
|
|
|
return corev1.ResourceRequirements{}, nil
|
|
}
|