Skip to content

Commit

Permalink
Update apis
Browse files Browse the repository at this point in the history
Signed-off-by: Md. Ishtiaq Islam <[email protected]>
  • Loading branch information
ishtiaqhimel committed Jul 18, 2024
1 parent c189406 commit 624e360
Show file tree
Hide file tree
Showing 19 changed files with 38,150 additions and 11,063 deletions.
31 changes: 17 additions & 14 deletions apis/constant.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,16 +49,18 @@ const (
PrefixRetentionPolicy = "retentionpolicy"
PrefixPopulate = "populate"
PrefixPrime = "prime"
PrefixVerify = "verify"
)

const (
KubeStashBackupComponent = "kubestash-backup"
KubeStashRestoreComponent = "kubestash-restore"
KubeStashInitializerComponent = "kubestash-initializer"
KubeStashUploaderComponent = "kubestash-uploader"
KubeStashCleanerComponent = "kubestash-cleaner"
KubeStashHookComponent = "kubestash-hook"
KubeStashPopulatorComponent = "kubestash-populator"
KubeStashBackupComponent = "kubestash-backup"
KubeStashRestoreComponent = "kubestash-restore"
KubeStashInitializerComponent = "kubestash-initializer"
KubeStashUploaderComponent = "kubestash-uploader"
KubeStashCleanerComponent = "kubestash-cleaner"
KubeStashHookComponent = "kubestash-hook"
KubeStashPopulatorComponent = "kubestash-populator"
KubeStashBackupVerificationComponent = "kubestash-backup-verification"
)

// Keys for offshoot labels
Expand Down Expand Up @@ -98,13 +100,14 @@ const (

// RBAC related
const (
KubeStashBackupJobClusterRole = "kubestash-backup-job"
KubeStashRestoreJobClusterRole = "kubestash-restore-job"
KubeStashCronJobClusterRole = "kubestash-cron-job"
KubeStashBackendJobClusterRole = "kubestash-backend-job"
KubeStashStorageInitializerClusterRole = "kubestash-storage-initializer-job"
KubeStashPopulatorJobClusterRole = "kubestash-populator-job"
KubeStashRetentionPolicyJobClusterRole = "kubestash-retention-policy-job"
KubeStashBackupJobClusterRole = "kubestash-backup-job"
KubeStashRestoreJobClusterRole = "kubestash-restore-job"
KubeStashCronJobClusterRole = "kubestash-cron-job"
KubeStashBackendJobClusterRole = "kubestash-backend-job"
KubeStashStorageInitializerClusterRole = "kubestash-storage-initializer-job"
KubeStashPopulatorJobClusterRole = "kubestash-populator-job"
KubeStashRetentionPolicyJobClusterRole = "kubestash-retention-policy-job"
KubeStashBackupVerificationJobClusterRole = "kubestash-backup-verification-job"
)

// Reconciliation related
Expand Down
4 changes: 4 additions & 0 deletions apis/core/v1alpha1/backupbatch_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,10 @@ type BackupBatchSpec struct {
// Session defines a list of session configurations that specifies when and how to take backup.
Sessions []BatchSession `json:"sessions,omitempty"`

// VerificationStrategies specifies a list of backup verification configurations
// +optional
VerificationStrategies []VerificationStrategy `json:"verificationStrategies,omitempty"`

// Paused indicates that the BackupBatch has been paused from taking backup. Default value is 'false'.
// If you set `paused` field to `true`, KubeStash will suspend the respective backup triggering CronJob and
// skip processing any further events for this BackupBatch.
Expand Down
199 changes: 186 additions & 13 deletions apis/core/v1alpha1/backupconfiguration_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,6 @@ import (

batchv1 "k8s.io/api/batch/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/runtime"
kmapi "kmodules.xyz/client-go/api/v1"
ofst "kmodules.xyz/offshoot-api/api/v1"
)
Expand Down Expand Up @@ -298,16 +297,9 @@ type VerificationStrategy struct {
// Name indicates the name of this strategy.
Name string `json:"name,omitempty"`

// Namespace specifies where the verification resources should be created.
Namespace string `json:"namespace,omitempty"`

// Verifier refers to the BackupVerification CR that defines how to verify this particular data.
Verifier *kmapi.ObjectReference `json:"verifier,omitempty"`

// Params specifies the parameters that will be used by the verifier.
// +kubebuilder:pruning:PreserveUnknownFields
// RestoreOption specifies the restore target, addonInfo and manifestOption for backup verification
// +optional
Params *runtime.RawExtension `json:"params,omitempty"`
RestoreOption *RestoreOption `json:"restoreOption,omitempty"`

// VerifySchedule specifies the schedule of backup verification in Cron format, see https://en.wikipedia.org/wiki/Cron.
VerifySchedule string `json:"verifySchedule,omitempty"`
Expand All @@ -316,13 +308,30 @@ type VerificationStrategy struct {
// +optional
KeepAlive *metav1.Time `json:"keepAlive,omitempty"`

// Tasks specifies a list of restore tasks and their configuration parameters for backup verification.
Tasks []TaskReference `json:"tasks,omitempty"`

// OnFailure specifies what to do if the verification fail.
// +optional
// OnFailure FailurePolicy `json:"onFailure,omitempty"`

// Type indicate the types of verifier that will verify the backup.
// Valid values are:
// - "RestoreOnly": KubeStash will create a RestoreSession with the tasks provided in BackupConfiguration's verificationStrategies section.
// - "File": KubeStash will restore the data and then create a job to check if the files exist or not. This type is recommended for workload backup verification.
// - "Query": KubeStash operator will restore data and then create a job to run the queries. This type is recommended for database backup verification.
// - "Script": KubeStash operator will restore data and then create a job to run the script. This type is recommended for database backup verification.
Type VerificationType `json:"type,omitempty"`

// File specifies the file paths information whose existence will be checked for backup verification.
// +optional
File *FileVerifierSpec `json:"file,omitempty"`

// Query specifies the queries to be run to verify backup.
// +optional
Query *QueryVerifierSpec `json:"query,omitempty"`

// Script specifies the script to be run to verify backup.
// +optional
Script *ScriptVerifierSpec `json:"script,omitempty"`

// RetryConfig specifies the behavior of the retry mechanism in case of a verification failure.
// +optional
RetryConfig *RetryConfig `json:"retryConfig,omitempty"`
Expand All @@ -339,6 +348,170 @@ type VerificationStrategy struct {
RuntimeSettings ofst.RuntimeSettings `json:"runtimeSettings,omitempty"`
}

type RestoreOption struct {
// Target indicates the target application where the data will be restored
// +optional
Target *kmapi.TypedObjectReference `json:"target,omitempty"`

// ManifestOptions provide options to select particular manifest object to restore
// +optional
ManifestOptions *ManifestRestoreOptions `json:"manifestOptions,omitempty"`

// AddonInfo specifies addon configuration that will be used to restore this target.
AddonInfo *AddonInfo `json:"addonInfo,omitempty"`
}

// VerificationType specifies the type of verifier that will verify the backup
// +kubebuilder:validation:Enum=RestoreOnly;File;Query;Script
type VerificationType string

const (
RestoreOnlyVerificationType VerificationType = "RestoreOnly"
FileVerificationType VerificationType = "File"
QueryVerificationType VerificationType = "Query"
ScriptVerificationType VerificationType = "Script"
)

// FileVerifierSpec defines the file paths information whose existence will be checked from verifier job.
type FileVerifierSpec struct {
// Paths specifies the list of paths whose existence will be checked.
// These paths must be absolute paths.
Paths []string `json:"paths,omitempty"`
}

// QueryVerifierSpec defines the queries to be run from verifier job.
type QueryVerifierSpec struct {
// MySQL specifies queries option for MySQL database
// +optional
MySQL []MySQLQueryOpt `json:"mysql,omitempty"`

// MariaDB specifies queries option for MariaDB database
// +optional
MariaDB []MariaDBQueryOpt `json:"mariaDB,omitempty"`

// Postgres specifies queries option for Postgres database
// +optional
Postgres []PostgresQueryOpt `json:"postgres,omitempty"`

// MongoDB specifies queries option for MongoDB database
// +optional
MongoDB []MongoDBQueryOpt `json:"mongodb,omitempty"`

// Elasticsearch specifies queries option for Elasticsearch database
// +optional
Elasticsearch []ElasticsearchQueryOpt `json:"elasticsearch,omitempty"`

// Redis specifies queries option for Redis database
// +optional
Redis []RedisQueryOpt `json:"redis,omitempty"`
}

// MySQLQueryOpt specifies queries option for MySQL database
type MySQLQueryOpt struct {
// Database refers to the database name being checked for existence
Database string `json:"database,omitempty"`

// Table refers to the table name being checked for existence in specified Database
// +optional
Table string `json:"table,omitempty"`

// RowCount represents the number of row to be checked in the specified Table
// +optional
RowCount *MatchExpression `json:"rowCount,omitempty"`
}

// MariaDBQueryOpt specifies queries option for MariaDB database
type MariaDBQueryOpt struct {
// Database refers to the database name being checked for existence
Database string `json:"database,omitempty"`

// Table refers to the table name being checked for existence in specified Database
// +optional
Table string `json:"table,omitempty"`

// RowCount represents the number of row to be checked in the specified Table
// +optional
RowCount *MatchExpression `json:"rowCount,omitempty"`
}

// PostgresQueryOpt specifies queries option for Postgres database
type PostgresQueryOpt struct {
// Database refers to the database name being checked for existence
Database string `json:"database,omitempty"`

// Schema refers to the schema name being checked for existence in specified Database
// +optional
Schema string `json:"schema,omitempty"`

// Table refers to the table name being checked for existence in specified Database
// +optional
Table string `json:"table,omitempty"`

// RowCount represents the number of row to be checked in the specified Table
// +optional
RowCount *MatchExpression `json:"rowCount,omitempty"`
}

// MongoDBQueryOpt specifies queries option for MongoDB database
type MongoDBQueryOpt struct {
// Database refers to the database name being checked for existence
Database string `json:"database,omitempty"`

// Collection refers to the collection name being checked for existence in specified Database
// +optional
Collection string `json:"collection,omitempty"`

// RowCount represents the number of document to be checked in the specified Collection
// +optional
DocumentCount *MatchExpression `json:"documentCount,omitempty"`
}

// ElasticsearchQueryOpt specifies queries option for Elasticsearch database
type ElasticsearchQueryOpt struct {
// Index refers to the index name being checked for existence
Index string `json:"index,omitempty"`
}

// RedisQueryOpt specifies queries option for Redis database
type RedisQueryOpt struct {
// Database refers to the database name being checked for existence
Database string `json:"database,omitempty"`

// DbSize specifies the number of keys in the specified Database
// +optional
DbSize *MatchExpression `json:"dbSize,omitempty"`
}

type MatchExpression struct {
// Operator represents the operation that will be done on the given Value
Operator Operator `json:"operator,omitempty"`

// Value represents the numerical value of the desired output
Value *int64 `json:"value,omitempty"`
}

// Operator represents the operation that will be done
// +kubebuilder:validation:Enum=Equal;NotEqual;LessThan;LessThanOrEqual;GreaterThan;GreaterThanOrEqual
type Operator string

const (
EqualOperator Operator = "Equal"
NotEqualOperator Operator = "NotEqual"
LessThanOperator Operator = "LessThan"
LessThanOrEqualOperator Operator = "LessThanOrEqual"
GreaterThanOperator Operator = "GreaterThan"
GreaterThanOrEqualOperator Operator = "GreaterThanOrEqual"
)

// ScriptVerifierSpec defines the script location in verifier job and the args to be provided with the script.
type ScriptVerifierSpec struct {
// Location specifies the absolute path of the script file's location.
Location string `json:"location,omitempty"`

// Args specifies the arguments to be provided with the script.
Args []string `json:"args,omitempty"`
}

// BackupHooks specifies the hooks that will be executed before and/or after backup
type BackupHooks struct {
// PreBackup specifies a list of hooks that will be executed before backup
Expand Down
8 changes: 4 additions & 4 deletions apis/core/v1alpha1/backupconfiguration_webhook.go
Original file line number Diff line number Diff line change
Expand Up @@ -448,12 +448,12 @@ func (b *BackupConfiguration) validateVerificationStrategies() error {
}

for _, vs := range b.Spec.VerificationStrategies {
if vs.Namespace == "" {
return fmt.Errorf("namespace for verification strategy %q cannot be empty", vs.Name)
if vs.RestoreOption == nil {
return fmt.Errorf("restoreOption for verification strategy %q cannot be empty", vs.Name)
}

if vs.Verifier == nil {
return fmt.Errorf("verifier for verification strategy %q cannot be empty", vs.Name)
if vs.RestoreOption.AddonInfo == nil {
return fmt.Errorf("addonInfo in restoreOption for verification strategy %q cannot be empty", vs.Name)
}

if vs.VerifySchedule == "" {
Expand Down
11 changes: 0 additions & 11 deletions apis/core/v1alpha1/backupsession_helpers.go
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,6 @@ func (b *BackupSession) CalculatePhase() BackupSessionPhase {
b.failedToExecutePreBackupHooks() ||
b.failedToExecutePostBackupHooks() ||
b.failedToApplyRetentionPolicy() ||
b.verificationsFailed() ||
b.sessionHistoryCleanupFailed()) {
return BackupSessionFailed
}
Expand Down Expand Up @@ -110,16 +109,6 @@ func (b *BackupSession) failedToApplyRetentionPolicy() bool {
return false
}

func (b *BackupSession) verificationsFailed() bool {
for _, v := range b.Status.Verifications {
if v.Phase == VerificationFailed {
return true
}
}

return false
}

func (b *BackupSession) calculateBackupSessionPhaseFromSnapshots() BackupSessionPhase {
status := b.Status.Snapshots
if len(status) == 0 {
Expand Down
42 changes: 0 additions & 42 deletions apis/core/v1alpha1/backupverification_helpers.go

This file was deleted.

Loading

0 comments on commit 624e360

Please sign in to comment.