From 855190f27bfb67a41bfc36f33886d5966df2f66d Mon Sep 17 00:00:00 2001 From: "Alexander A. Klimov" Date: Tue, 10 Oct 2023 11:19:48 +0200 Subject: [PATCH] Unify check attempt data type to uint32 already used somewhere A float isn't necessary as in Icinga 2 Checkable#max_check_attempts and check_attempt are ints. But uint8 isn't enough for e.g. 1 check/s to get HARD after 5m (300s > 255). --- cmd/icingadb-migrate/convert.go | 2 +- pkg/icingadb/v1/checkable.go | 2 +- pkg/icingadb/v1/history/state.go | 2 +- pkg/icingadb/v1/state.go | 2 +- tests/object_sync_test.go | 4 ++-- 5 files changed, 6 insertions(+), 6 deletions(-) diff --git a/cmd/icingadb-migrate/convert.go b/cmd/icingadb-migrate/convert.go index e14746e46..4767d86cc 100644 --- a/cmd/icingadb-migrate/convert.go +++ b/cmd/icingadb-migrate/convert.go @@ -813,7 +813,7 @@ func convertStateRows( HardState: row.LastHardState, PreviousSoftState: row.LastState, PreviousHardState: previousHardState, - CheckAttempt: uint8(row.CurrentCheckAttempt), + CheckAttempt: uint32(row.CurrentCheckAttempt), Output: icingadbTypes.String{NullString: row.Output}, LongOutput: icingadbTypes.String{NullString: row.LongOutput}, MaxCheckAttempts: uint32(row.MaxCheckAttempts), diff --git a/pkg/icingadb/v1/checkable.go b/pkg/icingadb/v1/checkable.go index dbb114cbc..4b1efeb9c 100644 --- a/pkg/icingadb/v1/checkable.go +++ b/pkg/icingadb/v1/checkable.go @@ -30,7 +30,7 @@ type Checkable struct { IconImageAlt string `json:"icon_image_alt"` IconImageId types.Binary `json:"icon_image_id"` IsVolatile types.Bool `json:"is_volatile"` - MaxCheckAttempts float64 `json:"max_check_attempts"` + MaxCheckAttempts uint32 `json:"max_check_attempts"` Notes string `json:"notes"` NotesUrlId types.Binary `json:"notes_url_id"` NotificationsEnabled types.Bool `json:"notifications_enabled"` diff --git a/pkg/icingadb/v1/history/state.go b/pkg/icingadb/v1/history/state.go index dec13b042..6320b738a 100644 --- a/pkg/icingadb/v1/history/state.go +++ b/pkg/icingadb/v1/history/state.go @@ -14,7 +14,7 @@ type StateHistory struct { HardState uint8 `json:"hard_state"` PreviousSoftState uint8 `json:"previous_soft_state"` PreviousHardState uint8 `json:"previous_hard_state"` - CheckAttempt uint8 `json:"check_attempt"` + CheckAttempt uint32 `json:"check_attempt"` Output types.String `json:"output"` LongOutput types.String `json:"long_output"` MaxCheckAttempts uint32 `json:"max_check_attempts"` diff --git a/pkg/icingadb/v1/state.go b/pkg/icingadb/v1/state.go index bad8f28c5..983b14d5a 100644 --- a/pkg/icingadb/v1/state.go +++ b/pkg/icingadb/v1/state.go @@ -9,7 +9,7 @@ type State struct { EnvironmentMeta `json:",inline"` AcknowledgementCommentId types.Binary `json:"acknowledgement_comment_id"` LastCommentId types.Binary `json:"last_comment_id"` - CheckAttempt uint8 `json:"check_attempt"` + CheckAttempt uint32 `json:"check_attempt"` CheckCommandline types.String `json:"check_commandline"` CheckSource types.String `json:"check_source"` SchedulingSource types.String `json:"scheduling_source"` diff --git a/tests/object_sync_test.go b/tests/object_sync_test.go index e2455ec47..b90fdcd84 100644 --- a/tests/object_sync_test.go +++ b/tests/object_sync_test.go @@ -655,7 +655,7 @@ type Host struct { Address string `icinga2:"address" icingadb:"address"` Address6 string `icinga2:"address6" icingadb:"address6"` CheckCommandName string `icinga2:"check_command" icingadb:"checkcommand_name"` - MaxCheckAttempts float64 `icinga2:"max_check_attempts" icingadb:"max_check_attempts"` + MaxCheckAttempts uint32 `icinga2:"max_check_attempts" icingadb:"max_check_attempts"` CheckPeriodName string `icinga2:"check_period" icingadb:"check_timeperiod_name"` CheckTimeout float64 `icinga2:"check_timeout" icingadb:"check_timeout"` CheckInterval float64 `icinga2:"check_interval" icingadb:"check_interval"` @@ -747,7 +747,7 @@ type Service struct { DisplayName string `icinga2:"display_name" icingadb:"display_name"` HostName *string `icinga2:"host_name,nomodify" icingadb:"host.name"` CheckCommandName string `icinga2:"check_command" icingadb:"checkcommand_name"` - MaxCheckAttempts float64 `icinga2:"max_check_attempts" icingadb:"max_check_attempts"` + MaxCheckAttempts uint32 `icinga2:"max_check_attempts" icingadb:"max_check_attempts"` CheckPeriodName string `icinga2:"check_period" icingadb:"check_timeperiod_name"` CheckTimeout float64 `icinga2:"check_timeout" icingadb:"check_timeout"` CheckInterval float64 `icinga2:"check_interval" icingadb:"check_interval"`