Skip to content

Commit 03789b8

Browse files
committed
feat: add WithPruneDisabled to syncoption
Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@ledger.fr>
1 parent 1460b8a commit 03789b8

File tree

1 file changed

+9
-1
lines changed

1 file changed

+9
-1
lines changed

pkg/sync/sync_context.go

Lines changed: 9 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -129,6 +129,13 @@ func WithPruneConfirmed(confirmed bool) SyncOpt {
129129
}
130130
}
131131

132+
// WithPruneDisabled specifies if prune is globally disabled for this application
133+
func WithPruneDisabled(disabled bool) SyncOpt {
134+
return func(ctx *syncContext) {
135+
ctx.pruneDisabled = disabled
136+
}
137+
}
138+
132139
// WithOperationSettings allows to set sync operation settings
133140
func WithOperationSettings(dryRun bool, prune bool, force bool, skipHooks bool) SyncOpt {
134141
return func(ctx *syncContext) {
@@ -382,6 +389,7 @@ type syncContext struct {
382389
prunePropagationPolicy *metav1.DeletionPropagation
383390
pruneConfirmed bool
384391
requiresPruneConfirmation bool
392+
pruneDisabled bool
385393
clientSideApplyMigrationManager string
386394
enableClientSideApplyMigration bool
387395

@@ -1208,7 +1216,7 @@ func (sc *syncContext) applyObject(t *syncTask, dryRun, validate bool) (common.R
12081216
func (sc *syncContext) pruneObject(liveObj *unstructured.Unstructured, prune, dryRun bool) (common.ResultCode, string) {
12091217
if !prune {
12101218
return common.ResultCodePruneSkipped, "ignored (requires pruning)"
1211-
} else if resourceutil.HasAnnotationOption(liveObj, common.AnnotationSyncOptions, common.SyncOptionDisablePrune) {
1219+
} else if resourceutil.HasAnnotationOption(liveObj, common.AnnotationSyncOptions, common.SyncOptionDisablePrune) || sc.pruneDisabled {
12121220
return common.ResultCodePruneSkipped, "ignored (no prune)"
12131221
}
12141222
if dryRun {

0 commit comments

Comments
 (0)