Documentation ¶
Index ¶
- Constants
- Variables
- func AssignMacAddress(clusterInput map[string]any, hwInterfacess []*hwv1alpha1.Interface, ...) error
- func ClusterIsReadyForPolicyConfig(ctx context.Context, c client.Client, clusterInstanceName string) (bool, error)
- func CollectNodeDetails(ctx context.Context, c client.Client, nodePool *hwv1alpha1.NodePool) (map[string][]NodeInfo, error)
- func CompareHardwareTemplateWithNodePool(hardwareTemplate *hwv1alpha1.HardwareTemplate, nodePool *hwv1alpha1.NodePool) (bool, error)
- func ConvertMapAnyToString(input map[string]any) map[string]string
- func CopyBMCSecrets(ctx context.Context, c client.Client, hwNodes map[string][]NodeInfo, ...) error
- func CopyK8sSecret(ctx context.Context, c client.Client, ...) error
- func CreateConfigMapFromEmbeddedFile(ctx context.Context, c client.Client, ownerObject client.Object, fs embed.FS, ...) error
- func CreateDefaultInventoryCR(ctx context.Context, c client.Client) error
- func CreateHwMgrPluginNamespace(ctx context.Context, c client.Client, name string) error
- func CreateK8sCR(ctx context.Context, c client.Client, newObject client.Object, ...) (err error)
- func CreateSecretFromLiterals(ctx context.Context, c client.Client, ownerObject client.Object, ...) error
- func DeepMergeMaps[K comparable, V any](dst, src map[K]V, checkType bool) error
- func DeepMergeSlices[K comparable, V any](dst, src []V, checkType bool) ([]V, error)
- func DoesK8SResourceExist(ctx context.Context, c client.Client, name, namespace string, ...) (resourceExists bool, err error)
- func ExtractBeforeDot(s string) string
- func ExtractMatchingInput(parentSchema []byte, subSchemaKey string) (any, error)
- func ExtractSchemaRequired(mainSchema []byte) (required []string, err error)
- func ExtractSubSchema(mainSchema []byte, subSchemaKey string) (subSchema map[string]any, err error)
- func ExtractTemplateDataFromConfigMap[T any](cm *corev1.ConfigMap, expectedKey string) (T, error)
- func ExtractTimeoutFromConfigMap(cm *corev1.ConfigMap, key string) (time.Duration, error)
- func FindClusterInstanceImmutableFieldUpdates(oldClusterInstance, newClusterInstance *unstructured.Unstructured) ([]string, []string, error)
- func GenerateSearchApiUrl(backendURL string) (string, error)
- func GetBackendTokenArg(backendToken string) string
- func GetBootMacAddress(interfaces []*hwv1alpha1.Interface, nodePool *hwv1alpha1.NodePool) (string, error)
- func GetCertFromSecret(ctx context.Context, c client.Client, name, namespace string) (*tls.Certificate, error)
- func GetClusterID(ctx context.Context, c client.Client, name string) (string, error)
- func GetConfigMapField(cm *corev1.ConfigMap, fieldName string) (string, error)
- func GetConfigmap(ctx context.Context, c client.Client, name, namespace string) (*corev1.ConfigMap, error)
- func GetDatabaseHostname() string
- func GetDefaultBackendTransport() (http.RoundTripper, error)
- func GetDefaultTLSConfig(config *tls.Config) (*tls.Config, error)
- func GetDeploymentVolumeMounts(serverName string) []corev1.VolumeMount
- func GetDeploymentVolumes(serverName string) []corev1.Volume
- func GetEnvOrDefault(name, defaultValue string) string
- func GetHardwareTemplate(ctx context.Context, c client.Client, hwTemplateName string) (*hwv1alpha1.HardwareTemplate, error)
- func GetHwMgrPluginNS() string
- func GetIBGUFromUpgradeDefaultsConfigmap(ctx context.Context, c client.Client, cmName string, cmNamespace string, ...) (*ibguv1alpha1.ImageBasedGroupUpgrade, error)
- func GetIngressDomain(ctx context.Context, c client.Client) (string, error)
- func GetParentPolicyNameAndNamespace(childPolicyName string) (policyName, policyNamespace string)
- func GetPasswordOrRandom(envName string) string
- func GetRoleToGroupNameMap(nodePool *hwv1alpha1.NodePool) map[string]string
- func GetSearchAPI(ctx context.Context, c client.Client) (*corev1.Service, error)
- func GetSearchURL(ctx context.Context, c client.Client) (string, error)
- func GetSecret(ctx context.Context, c client.Client, name, namespace string) (*corev1.Secret, error)
- func GetSecretField(secret *corev1.Secret, fieldName string) (string, error)
- func GetServerArgs(inventory *inventoryv1alpha1.Inventory, serverName string) (result []string, err error)
- func GetServerDatabasePasswordName(serverName string) (string, error)
- func GetServiceURL(serverName string) string
- func GetStatusMessage(condition hwv1alpha1.ConditionType) string
- func GetTLSSkipVerify() bool
- func GetTimeoutFromHWTemplate(ctx context.Context, c client.Client, name string) (time.Duration, error)
- func HandleHardwareTimeout(condition hwv1alpha1.ConditionType, provisioningStartTime metav1.Time, ...) (bool, string, string)
- func HasApiEndpoints(serverName string) bool
- func HasDatabase(serverName string) bool
- func HwMgrPluginNamespaceExists(ctx context.Context, c client.Client, name string) (bool, error)
- func IsClusterProvisionCompleted(cr *provisioningv1alpha1.ProvisioningRequest) bool
- func IsClusterProvisionFailed(cr *provisioningv1alpha1.ProvisioningRequest) bool
- func IsClusterProvisionPresent(cr *provisioningv1alpha1.ProvisioningRequest) bool
- func IsClusterProvisionTimedOutOrFailed(cr *provisioningv1alpha1.ProvisioningRequest) bool
- func IsClusterUpgradeCompleted(cr *provisioningv1alpha1.ProvisioningRequest) bool
- func IsClusterUpgradeInProgress(cr *provisioningv1alpha1.ProvisioningRequest) bool
- func IsClusterUpgradeInitiated(cr *provisioningv1alpha1.ProvisioningRequest) bool
- func IsConditionDoesNotExistsErr(err error) bool
- func IsInputError(err error) bool
- func IsParentPolicyInZtpClusterTemplateNs(policyNamespace, ctNamespace string) bool
- func IsProvisioningStateFulfilled(cr *provisioningv1alpha1.ProvisioningRequest) bool
- func IsSmoRegistrationCompleted(cr *inventoryv1alpha1.Inventory) bool
- func MakeUUIDFromName(namespace string, cloudID uuid.UUID, name string) uuid.UUID
- func MapKeysToSlice(inputMap map[string]bool) []string
- func NewNodeGroup(group hwv1alpha1.NodePoolData, roleCounts map[string]int) hwv1alpha1.NodeGroup
- func RenderTemplateForK8sCR(templateName, templatePath string, templateDataObj map[string]any) (*unstructured.Unstructured, error)
- func SetNodePoolAnnotations(nodePool *hwv1alpha1.NodePool, name, value string)
- func SetNodePoolLabels(nodePool *hwv1alpha1.NodePool, label, value string)
- func SetProvisioningStateDeleting(cr *provisioningv1alpha1.ProvisioningRequest)
- func SetProvisioningStateFailed(cr *provisioningv1alpha1.ProvisioningRequest, message string)
- func SetProvisioningStateFulfilled(cr *provisioningv1alpha1.ProvisioningRequest)
- func SetProvisioningStateInProgress(cr *provisioningv1alpha1.ProvisioningRequest, message string)
- func SetStatusCondition(existingConditions *[]metav1.Condition, conditionType ConditionType, ...)
- func SetupOAuthClient(ctx context.Context, config OAuthClientConfig) (*http.Client, error)
- func TimeoutExceeded(startTime time.Time, timeout time.Duration) bool
- func UpdateHardwareTemplateStatusCondition(ctx context.Context, c client.Client, ...) error
- func UpdateK8sCRStatus(ctx context.Context, c client.Client, object client.Object) error
- func UpdateNodeStatusWithHostname(ctx context.Context, c client.Client, nodeName, hostname, namespace string) error
- func ValidateDefaultInterfaces[T any](data T) error
- type AvailableNotification
- type ConditionDoesNotExistsErr
- type ConditionReason
- type ConditionType
- type InputError
- type InventoryConditionReason
- type InventoryConditionType
- type NodeInfo
- type OAuthClientConfig
Constants ¶
const ( InventoryDatabase = "postgres" InventoryMetadata = "metadata" InventoryDeploymentManager = "deployment-manager" InventoryResource = "resource" InventoryAlarms = "alarms" InventoryCluster = "cluster" )
Base resource names
const ( InventoryDatabaseServerName = InventoryDatabase + serverSuffix InventoryMetadataServerName = InventoryMetadata + serverSuffix InventoryDeploymentManagerServerName = InventoryDeploymentManager + serverSuffix InventoryResourceServerName = InventoryResource + serverSuffix InventoryAlarmServerName = InventoryAlarms + serverSuffix InventoryClusterServerName = InventoryCluster + serverSuffix )
Deployment names
const ( UPDATE = "Update" PATCH = "Patch" )
Resource operations
const ( DefaultInventoryCR = "default" DefaultNamespace = "oran-o2ims" DefaultNamespaceEnvName = "OCLOUD_MANAGER_NAMESPACE" )
Defines information related to the operator instance in a namespace
const ( SearchApiLabelKey = "search-monitor" SearchApiLabelValue = "search-api" )
Search API attributes
const ( DefaultBackendTokenFile = "/var/run/secrets/kubernetes.io/serviceaccount/token" // nolint: gosec // hardcoded path only DefaultServiceCAFile = "/var/run/secrets/kubernetes.io/serviceaccount/service-ca.crt" // nolint: gosec // hardcoded path only )
Default values for backend URL and token:
const ( DefaultHardwareProvisioningTimeout = 90 * time.Minute DefaultClusterInstallationTimeout = 90 * time.Minute DefaultClusterConfigurationTimeout = 30 * time.Minute )
Default timeout values
const ( HardwareProvisioningTimeoutConfigKey = "hardwareProvisioningTimeout" ClusterInstallationTimeoutConfigKey = "clusterInstallationTimeout" ClusterConfigurationTimeoutConfigKey = "clusterConfigurationTimeout" )
These are optional keys in the respective ConfigMaps defined in ClusterTemplate spec.templates, used to configure the timeout values for each operation. If not specified, the default timeout values will be applied.
const ( TemplateParamNodeClusterName = "nodeClusterName" TemplateParamOCloudSiteId = "oCloudSiteId" TemplateParamClusterInstance = "clusterInstanceParameters" TemplateParamPolicyConfig = "policyTemplateParameters" )
Required template schema parameters
const ( ClusterInstanceTemplateName = "ClusterInstance" ClusterInstanceTemplatePath = "controllers/clusterinstance-template.yaml" ClusterInstanceTemplateDefaultsConfigmapKey = "clusterinstance-defaults" )
ClusterInstance template constants
const ( PolicyTemplateDefaultsConfigmapKey = "policytemplate-defaults" ClusterVersionLabelKey = "cluster-version" )
PolicyTemplate constants
const ( ClusterZtpDone = "ZTP Done" ClusterZtpNotDone = "ZTP Not Done" )
Cluster status
const ( HwTemplatePluginMgr = "hwMgrId" HwTemplateNodePool = "node-pools-data" HwTemplateBootIfaceLabel = "bootInterfaceLabel" HwTemplateExtensions = "extensions" )
Hardeware template constants
const ( OperationTypeCreated = "created" OperationTypeUpdated = "updated" OperationTypeDryRun = "validated with dry-run" )
const ( TLSSkipVerifyEnvName = "INSECURE_SKIP_VERIFY" TLSSkipVerifyDefaultValue = false )
Environment variable names
const ( ChildPolicyRootPolicyLabel = "policy.open-cluster-management.io/root-policy" ChildPolicyClusterNameLabel = "policy.open-cluster-management.io/cluster-name" ChildPolicyClusterNamespaceLabel = "policy.open-cluster-management.io/cluster-namespace" )
Label specific to ACM child policies.
const ( UnitTestHwmgrID = "hwmgr" UnitTestHwmgrNamespace = "hwmgr" DefaultPluginNamespace = "oran-hwmgr-plugin" )
Hardware Manager plugin constants
const ( MigrationContainerName = "migration" RbacContainerName = "rbac" ServerContainerName = "server" )
POD Container Names
const ( DefaultServicePort = 8000 DefaultTargetPort = "https" DefaultContainerPort = 8000 DatabaseServicePort = 5432 DatabaseTargetPort = "database" )
POD Port Values
const ( ServerImageName = "IMAGE" KubeRbacProxyImageName = "KUBE_RBAC_PROXY_IMAGE" PostgresImageName = "POSTGRES_IMAGE" HwMgrPluginNameSpace = "HWMGR_PLUGIN_NAMESPACE" )
Environment values
const ( AdminPasswordEnvName = "POSTGRESQL_ADMIN_PASSWORD" // nolint: gosec AlarmsPasswordEnvName = "ORAN_O2IMS_ALARMS_PASSWORD" // nolint: gosec ResourcesPasswordEnvName = "ORAN_O2IMS_RESOURCES_PASSWORD" // nolint: gosec ClustersPasswordEnvName = "ORAN_O2IMS_CLUSTERS_PASSWORD" // nolint: gosec DatabaseHostnameEnvVar = "POSTGRES_HOSTNAME" )
Postgres values
const ( ClusterModelExtension = "model" ClusterVersionExtension = "version" ClusterVendorExtension = "vendor" ClusterModelHubCluster = "hub-cluster" ClusterModelManagedCluster = "managed-cluster" OpenshiftVersionLabelName = "openshiftVersion" ClusterIDLabelName = "clusterID" LocalClusterLabelName = "local-cluster" )
NodeCluster/ClusterResource extensions
const ( AlertmanagerObjectName = "alertmanager" AlertmanagerNamespace = "open-cluster-management-observability" AlertmanagerSA = "alertmanager" )
Alertmanager values
const ClusterInstanceParamsSubSchemaForNoHWTemplate = `` /* 871-byte string literal not displayed */
ClusterInstanceParamsSubSchemaForNoHWTemplate is the expected subschema for the ClusterInstanceParams when no hardware template is provided.
const ClusterVersionName = "version"
ClusterVersionName is the name given to the default ClusterVersion object
const DefaultAppName = "o2ims"
DefaultAppName defines the name prepended to the ingress host to form our FQDN hostname.
const DefaultOCloudID = "undefined"
DefaultOCloudID defines the default Global O-Cloud ID to be used until the end user configures this value.
const InventoryIngressName = "api"
InventoryIngressName the name of our Ingress controller instance
const (
InventoryNamespace = "oran-o2ims"
)
Default namespace
const (
PropertiesString = "properties"
)
const (
UpgradeDefaultsConfigmapKey = "ibgu"
)
Upgrade constants
Variables ¶
var ( AlarmServerArgs = []string{ "alarms-server", "serve", "--api-listener-address=127.0.0.1:8000", } MetadataServerArgs = []string{ "start", "metadata-server", "--log-level=debug", "--log-file=stdout", "--api-listener-address=127.0.0.1:8000", } DeploymentManagerServerArgs = []string{ "start", "deployment-manager-server", "--log-level=debug", "--log-file=stdout", "--api-listener-address=127.0.0.1:8000", } ResourceServerArgs = []string{ "start", "resource-server", "--log-level=debug", "--log-file=stdout", "--api-listener-address=127.0.0.1:8000", } ClusterServerArgs = []string{ "cluster-server", "serve", "--api-listener-address=127.0.0.1:8000", } )
Container arguments
var ( // AllowedClusterInstanceFields contains path patterns for fields that are allowed to be updated. // The wildcard "*" is used to match any index in a list. AllowedClusterInstanceFields = [][]string{ {"extraAnnotations"}, {"extraLabels"}, {"nodes", "*", "extraAnnotations"}, {"nodes", "*", "extraLabels"}, } // IgnoredClusterInstanceFields contains path patterns for fields that should be ignored. // The wildcard "*" is used to match any index in a list. IgnoredClusterInstanceFields = [][]string{ {"nodes", "*", "bmcAddress"}, {"nodes", "*", "bmcCredentialsName"}, {"nodes", "*", "bootMACAddress"}, {"nodes", "*", "nodeNetwork", "interfaces", "*", "macAddress"}, {"suppressedManifests"}, } )
var (
CRDsToBeSuppressedForUpgrade = []string{
"AgentClusterInstall",
}
)
CRDs needed to be suppressed in ClusterInstance for upgrade
var CRconditionReasons = struct { NotApplied ConditionReason ClusterNotReady ConditionReason Completed ConditionReason Failed ConditionReason InProgress ConditionReason Missing ConditionReason OutOfDate ConditionReason TimedOut ConditionReason Unknown ConditionReason }{ NotApplied: "NotApplied", ClusterNotReady: "ClusterNotReady", Completed: "Completed", Failed: "Failed", InProgress: "InProgress", Missing: "Missing", OutOfDate: "OutOfDate", TimedOut: "TimedOut", Unknown: "Unknown", }
The following constants define the different reasons that conditions will be set for ProvisioningRequest
var CTconditionReasons = struct { Completed ConditionReason Failed ConditionReason }{ Completed: "Completed", Failed: "Failed", }
The following constants define the different reasons that conditions will be set for ClusterTemplate
var CTconditionTypes = struct { Validated ConditionType }{ Validated: "ClusterTemplateValidated", }
The following constants define the different types of conditions that will be set for ClusterTemplate
var InventoryConditionReasons = struct { DeploymentsReady InventoryConditionReason ErrorGettingDeploymentInformation InventoryConditionReason DatabaseDeploymentFailed InventoryConditionReason DeploymentNotFound InventoryConditionReason ServerArgumentsError InventoryConditionReason SmoRegistrationSuccessful InventoryConditionReason SmoRegistrationFailed InventoryConditionReason SmoNotConfigured InventoryConditionReason }{ DatabaseDeploymentFailed: "DatabaseDeploymentFailed", DeploymentsReady: "AllDeploymentsReady", ErrorGettingDeploymentInformation: "ErrorGettingDeploymentInformation", DeploymentNotFound: "DeploymentNotFound", ServerArgumentsError: "ServerArgumentsError", SmoRegistrationSuccessful: "SmoRegistrationSuccessful", SmoRegistrationFailed: "SmoRegistrationFailed", SmoNotConfigured: "SmoNotConfigured", }
var InventoryConditionTypes = struct { Ready InventoryConditionType NotReady InventoryConditionType Error InventoryConditionType Available InventoryConditionType MetadataServerAvailable InventoryConditionType DeploymentServerAvailable InventoryConditionType ResourceServerAvailable InventoryConditionType AlarmServerError InventoryConditionType DatabaseServerError InventoryConditionType MetadataServerError InventoryConditionType DeploymentServerError InventoryConditionType ResourceServerError InventoryConditionType SmoRegistrationCompleted InventoryConditionType DatabaseServerAvailable InventoryConditionType AlarmServerAvailable InventoryConditionType }{ Ready: "InventoryReady", NotReady: "InventoryConditionType", Error: "Error", Available: "Available", MetadataServerAvailable: "MetadataServerAvailable", DeploymentServerAvailable: "DeploymentServerAvailable", ResourceServerAvailable: "ResourceServerAvailable", AlarmServerError: "AlarmServerError", DatabaseServerError: "DatabaseServerError", MetadataServerError: "MetadataServerError", DeploymentServerError: "DeploymentServerError", ResourceServerError: "ResourceServerError", SmoRegistrationCompleted: "SmoRegistrationCompleted", DatabaseServerAvailable: "DatabaseServerAvailable", AlarmServerAvailable: "AlarmServerAvailable", }
var MapAvailableDeploymentNameConditionType = map[string]InventoryConditionType{ InventoryAlarmServerName: InventoryConditionTypes.AlarmServerAvailable, InventoryDatabaseServerName: InventoryConditionTypes.DatabaseServerAvailable, InventoryMetadataServerName: InventoryConditionTypes.MetadataServerAvailable, InventoryDeploymentManagerServerName: InventoryConditionTypes.DeploymentServerAvailable, InventoryResourceServerName: InventoryConditionTypes.ResourceServerAvailable, }
var MapErrorDeploymentNameConditionType = map[string]InventoryConditionType{ InventoryAlarmServerName: InventoryConditionTypes.AlarmServerError, InventoryMetadataServerName: InventoryConditionTypes.MetadataServerError, InventoryDeploymentManagerServerName: InventoryConditionTypes.DeploymentServerError, InventoryResourceServerName: InventoryConditionTypes.ResourceServerError, InventoryDatabaseServerName: InventoryConditionTypes.DatabaseServerError, }
var PRconditionTypes = struct { Validated ConditionType HardwareTemplateRendered ConditionType HardwareProvisioned ConditionType HardwareNodeConfigApplied ConditionType HardwareConfigured ConditionType ClusterInstanceRendered ConditionType ClusterResourcesCreated ConditionType ClusterInstanceProcessed ConditionType ClusterProvisioned ConditionType ConfigurationApplied ConditionType UpgradeCompleted ConditionType }{ Validated: "ProvisioningRequestValidated", HardwareTemplateRendered: "HardwareTemplateRendered", HardwareProvisioned: "HardwareProvisioned", HardwareNodeConfigApplied: "HardwareNodeConfigApplied", HardwareConfigured: "HardwareConfigured", ClusterInstanceRendered: "ClusterInstanceRendered", ClusterResourcesCreated: "ClusterResourcesCreated", ClusterInstanceProcessed: "ClusterInstanceProcessed", ClusterProvisioned: "ClusterProvisioned", ConfigurationApplied: "ConfigurationApplied", UpgradeCompleted: "UpgradeCompleted", }
The following constants define the different types of conditions that will be set for ProvisioningRequest
Functions ¶
func AssignMacAddress ¶
func AssignMacAddress(clusterInput map[string]any, hwInterfacess []*hwv1alpha1.Interface, nodeSpec *siteconfig.NodeSpec) error
AssignMacAddress assigns a MAC address to a node interface based on matching criteria. Parameters:
- clusterInput: A map containing the merged cluster input data. It should include a "nodes" key with a slice of node data that specifies interface details.
- hwInterfaces: A slice of hardware interfaces containing MAC address and label information.
- nodeSpec: A reference to the node specification where the MAC address will be assigned.
Returns: - error: An error if any unexpected structure or data is encountered; otherwise, nil.
func ClusterIsReadyForPolicyConfig ¶
func ClusterIsReadyForPolicyConfig( ctx context.Context, c client.Client, clusterInstanceName string) (bool, error)
ClusterIsReadyForPolicyConfig checks if a cluster is ready for policy configuration by looking at its availability, joined status and hub acceptance.
func CollectNodeDetails ¶
func CollectNodeDetails(ctx context.Context, c client.Client, nodePool *hwv1alpha1.NodePool) (map[string][]NodeInfo, error)
CollectNodeDetails collects BMC and node interfaces details
func CompareHardwareTemplateWithNodePool ¶
func CompareHardwareTemplateWithNodePool(hardwareTemplate *hwv1alpha1.HardwareTemplate, nodePool *hwv1alpha1.NodePool) (bool, error)
CompareHardwareTemplateWithNodePool checks if there are any changes in the hardware template resource
func ConvertMapAnyToString ¶
ConvertMapAnyToString converts a map of any to a map of strings. Values not of type string are ignored.
func CopyBMCSecrets ¶
func CopyBMCSecrets(ctx context.Context, c client.Client, hwNodes map[string][]NodeInfo, nodePool *hwv1alpha1.NodePool) error
CopyBMCSecrets copies BMC secrets from the plugin namespace to the cluster namespace.
func CopyK8sSecret ¶
func CopyK8sSecret(ctx context.Context, c client.Client, secretName, sourceNamespace, targetNamespace string) error
CopyK8sSecret copies a secret from one namespace to another.
func CreateConfigMapFromEmbeddedFile ¶
func CreateConfigMapFromEmbeddedFile(ctx context.Context, c client.Client, ownerObject client.Object, fs embed.FS, path, namespace, name, key string) error
CreateConfigMapFromEmbeddedFile extracts a file from an embedded file system and builds a ConfigMap. If the file does not exist or is not accessible then an error is returned.
func CreateDefaultInventoryCR ¶
CreateDefaultInventoryCR creates the default Inventory CR so that the system has running servers
func CreateHwMgrPluginNamespace ¶
CreateHwMgrPluginNamespace creates the namespace of the hardware manager plugin where the node pools resource resides
func CreateK8sCR ¶
func CreateK8sCR(ctx context.Context, c client.Client, newObject client.Object, ownerObject client.Object, operation string) (err error)
CreateK8sCR creates/updates/patches an object.
func CreateSecretFromLiterals ¶
func CreateSecretFromLiterals(ctx context.Context, c client.Client, ownerObject client.Object, namespace, name string, literals map[string][]byte) error
CreateSecretFromLiterals takes a map of key value pairs and produces a Secret.
func DeepMergeMaps ¶
func DeepMergeMaps[K comparable, V any](dst, src map[K]V, checkType bool) error
DeepMergeMaps performs a deep merge of the src map into the dst map. Merge rules:
- If a key exists in both src and dst maps: a. If the values are of different types and matched type is required, it returns an error, otherwise, the src values overrides the dst element. b. If the values are both maps, recursively merge them. c. If the values are both slices, deeply merge the slices. d. For other types, the src value overrides the dst value.
- If a key exists only in src, add it to dst.
- If a key exists only in dst, preserve it.
func DeepMergeSlices ¶
func DeepMergeSlices[K comparable, V any](dst, src []V, checkType bool) ([]V, error)
DeepMergeSlices performs a deep indexing merge of the src slice into the dst slice. Merge rules:
- For elements present in both src and dst slices at the same index: a. If the elements are of different types and matched type is required, it returns an error, otherwise, the src element overrides the dst element. b. If the elements are both maps, deeply merge them. c. For other types, the src element overrides the dst element.
- If the src slice is longer, append the additional elements from src to dst.
- If the dst slice is longer, preserve the additional elements from dst.
func DoesK8SResourceExist ¶
func ExtractBeforeDot ¶
ExtractBeforeDot returns the strubstring before the first dot.
func ExtractMatchingInput ¶
ExtractMatchingInput extracts the portion of the input data that corresponds to a given subSchema key.
func ExtractSchemaRequired ¶
ExtractSchemaRequired extracts the required field of a subschema
func ExtractSubSchema ¶
ExtractSubSchema extracts a Sub schema indexed by subSchemaKey from a Main schema
func ExtractTemplateDataFromConfigMap ¶
ExtractTemplateDataFromConfigMap extracts the template data associated with the specified key from the provided ConfigMap. The data is expected to be in YAML format.
func ExtractTimeoutFromConfigMap ¶
ExtractTimeoutFromConfigMap extracts the timeout config from the ConfigMap by key if exits. converting it from duration string to time.Duration. Returns an error if the value is not a valid duration string.
func FindClusterInstanceImmutableFieldUpdates ¶
func FindClusterInstanceImmutableFieldUpdates( oldClusterInstance, newClusterInstance *unstructured.Unstructured) ([]string, []string, error)
FindClusterInstanceImmutableFieldUpdates identifies updates made to immutable fields in the ClusterInstance spec. It returns two lists of paths: a list of updated fields that are considered immutable and should not be modified and a list of fields related to node scaling, indicating nodes that were added or removed.
func GenerateSearchApiUrl ¶
GenerateSearchApiUrl appends graphql path to the backend URL to form the fully qualified search path
func GetBackendTokenArg ¶
func GetBootMacAddress ¶
func GetBootMacAddress(interfaces []*hwv1alpha1.Interface, nodePool *hwv1alpha1.NodePool) (string, error)
GetBootMacAddress selects the boot interface based on label and return the interface MAC address
func GetCertFromSecret ¶
func GetCertFromSecret(ctx context.Context, c client.Client, name, namespace string) (*tls.Certificate, error)
GetCertFromSecret retrieves an X.509 certificate from a Secret
func GetClusterID ¶
GetClusterID retrieves the UUID value for the cluster specified by name
func GetConfigMapField ¶
GetConfigMapField attempts to retrieve the value of the field using the provided field name
func GetConfigmap ¶
func GetConfigmap(ctx context.Context, c client.Client, name, namespace string) (*corev1.ConfigMap, error)
GetConfigmap attempts to retrieve a ConfigMap object for the given name
func GetDatabaseHostname ¶
func GetDatabaseHostname() string
GetDatabaseHostname returns the URL used to access the database service
func GetDefaultBackendTransport ¶
func GetDefaultBackendTransport() (http.RoundTripper, error)
GetDefaultBackendTransport returns an HTTP transport with the proper TLS defaults set.
func GetDefaultTLSConfig ¶
GetDefaultTLSConfig sets the TLS configuration attributes appropriately to enable communication between internal services and accessing the public facing API endpoints.
func GetDeploymentVolumeMounts ¶
func GetDeploymentVolumeMounts(serverName string) []corev1.VolumeMount
func GetDeploymentVolumes ¶
func GetEnvOrDefault ¶
GetEnvOrDefault returns the value of the named environment variable or the supplied default value if the environment variable is not set.
func GetHardwareTemplate ¶
func GetHardwareTemplate(ctx context.Context, c client.Client, hwTemplateName string) (*hwv1alpha1.HardwareTemplate, error)
GetHardwareTemplate retrieves the hardware template resource for a given name
func GetHwMgrPluginNS ¶
func GetHwMgrPluginNS() string
GetHwMgrPluginNS returns the value of environment variable HWMGR_PLUGIN_NAMESPACE
func GetIngressDomain ¶
GetIngressDomain will determine the network domain of the default ingress controller
func GetParentPolicyNameAndNamespace ¶
GetParentPolicyNameAndNamespace extracts the parent policy name and namespace from the child policy name. The child policy name follows the format: "<parent_policy_namespace>.<parent_policy_name>". Since the namespace is disallowed to contain ".", splitting the string with "." into two substrings is safe.
func GetPasswordOrRandom ¶
GetPasswordOrRandom attempts to query a password from the environment and generates a random password if none was found matching the supplied environment variable name.
func GetRoleToGroupNameMap ¶
func GetRoleToGroupNameMap(nodePool *hwv1alpha1.NodePool) map[string]string
GetRoleToGroupNameMap creates a mapping of Role to Group Name from NodePool
func GetSearchAPI ¶
GetSearchAPI attempts to find the search-api service using its label selector
func GetSearchURL ¶
GetSearchURL attempts to build the Search API service URL by dynamically looking up the service.
func GetSecret ¶
func GetSecret(ctx context.Context, c client.Client, name, namespace string) (*corev1.Secret, error)
GetSecret attempts to retrieve a Secret object for the given name
func GetSecretField ¶
GetSecretField attempts to retrieve the value of the field using the provided field name
func GetServerArgs ¶
func GetServerArgs(inventory *inventoryv1alpha1.Inventory, serverName string) (result []string, err error)
func GetServerDatabasePasswordName ¶
GetServerDatabasePasswordName retrieves name of the environment variable used to store the server's database password
func GetServiceURL ¶
GetServiceURL constructs the default service URL for a server
func GetStatusMessage ¶
func GetStatusMessage(condition hwv1alpha1.ConditionType) string
GetStatusMessage returns a status message based on the given condition typ
func GetTLSSkipVerify ¶
func GetTLSSkipVerify() bool
GetTLSSkipVerify returns the current requested value of the TLS Skip Verify setting
func GetTimeoutFromHWTemplate ¶
func GetTimeoutFromHWTemplate(ctx context.Context, c client.Client, name string) (time.Duration, error)
GetTimeoutFromHWTemplate retrieves the timeout value from the hardware template resource. converting it from duration string to time.Duration. Returns an error if the value is not a valid duration string.
func HandleHardwareTimeout ¶
func HandleHardwareTimeout( condition hwv1alpha1.ConditionType, provisioningStartTime metav1.Time, configurationStartTime metav1.Time, timeout time.Duration, currentReason string, currentMessage string) (bool, string, string)
HandleHardwareTimeout checks for provisioning or configuration timeout
func HasApiEndpoints ¶
HasApiEndpoints determines whether a server exposes a set of API endpoints
func HasDatabase ¶
HasDatabase determines whether a server owns a logical database instance
func HwMgrPluginNamespaceExists ¶
HwMgrPluginNamespaceExists checks if the namespace of the hardware manager plugin exists
func IsClusterProvisionCompleted ¶
func IsClusterProvisionCompleted(cr *provisioningv1alpha1.ProvisioningRequest) bool
IsClusterProvisionCompleted checks if the cluster provision condition status is completed. The staleCondition is set when the ClusterDeployment's spec.installed has become true, but its status conditions have not been properly updated due to the known issue (https://issues.redhat.com/browse/ACM-13064). In this case, the cluster has actually been successfully installed and is ready for configuration, but the status wasn't updated correctly. Therefore, we treat it as completed so that the provisioningStatus be updated properly. This workaround can be removed after ACM 2.12 GA.
func IsClusterProvisionFailed ¶
func IsClusterProvisionFailed(cr *provisioningv1alpha1.ProvisioningRequest) bool
IsClusterProvisionFailed checks if the cluster provision condition status is failed
func IsClusterProvisionPresent ¶
func IsClusterProvisionPresent(cr *provisioningv1alpha1.ProvisioningRequest) bool
IsClusterProvisionPresent checks if the cluster provision condition is present
func IsClusterProvisionTimedOutOrFailed ¶
func IsClusterProvisionTimedOutOrFailed(cr *provisioningv1alpha1.ProvisioningRequest) bool
IsClusterProvisionTimedOutOrFailed checks if the cluster provision condition status is timedout or failed
func IsClusterUpgradeCompleted ¶
func IsClusterUpgradeCompleted(cr *provisioningv1alpha1.ProvisioningRequest) bool
IsClusterUpgradeCompleted checks if the cluster upgrade is completed
func IsClusterUpgradeInProgress ¶
func IsClusterUpgradeInProgress(cr *provisioningv1alpha1.ProvisioningRequest) bool
IsClusterUpgradeInProgress checks if the cluster upgrade condition status is in progress
func IsClusterUpgradeInitiated ¶
func IsClusterUpgradeInitiated(cr *provisioningv1alpha1.ProvisioningRequest) bool
IsClusterUpgradeInitiated checks if the cluster upgrade is initiated
func IsConditionDoesNotExistsErr ¶
IsConditionDoesNotExistsErr checks if the given error is of type ConditionDoesNotExistsErr
func IsInputError ¶
func IsParentPolicyInZtpClusterTemplateNs ¶
IsParentPolicyInZtpClusterTemplateNs checks whether the parent policy resides in the namespace "ztp-<clustertemplate-ns>".
func IsProvisioningStateFulfilled ¶
func IsProvisioningStateFulfilled(cr *provisioningv1alpha1.ProvisioningRequest) bool
IsProvisioningStateFulfilled checks if the provisioning status is fulfilled
func IsSmoRegistrationCompleted ¶
func IsSmoRegistrationCompleted(cr *inventoryv1alpha1.Inventory) bool
IsSmoRegistrationCompleted checks if registration with SMO has been completed
func MakeUUIDFromName ¶
MakeUUIDFromName generates a namespaced uuid value from the specified namespace and name values. The values are scoped to a `cloudID` to avoid conflicts with other systems.
func MapKeysToSlice ¶
MapKeysToSlice takes a map[string]bool and returns a slice of strings containing the keys
func NewNodeGroup ¶
func NewNodeGroup(group hwv1alpha1.NodePoolData, roleCounts map[string]int) hwv1alpha1.NodeGroup
NewNodeGroup populates NodeGroup
func RenderTemplateForK8sCR ¶
func RenderTemplateForK8sCR(templateName, templatePath string, templateDataObj map[string]any) (*unstructured.Unstructured, error)
RenderTemplateForK8sCR returns a rendered K8s resource with an given template and object data
func SetNodePoolAnnotations ¶
func SetNodePoolAnnotations(nodePool *hwv1alpha1.NodePool, name, value string)
SetNodePoolAnnotations sets annotations on the NodePool
func SetNodePoolLabels ¶
func SetNodePoolLabels(nodePool *hwv1alpha1.NodePool, label, value string)
SetNodePoolLabels sets labels on the NodePool
func SetProvisioningStateDeleting ¶
func SetProvisioningStateDeleting(cr *provisioningv1alpha1.ProvisioningRequest)
SetProvisioningStateDeleting updates the provisioning state to deleting with detailed message
func SetProvisioningStateFailed ¶
func SetProvisioningStateFailed(cr *provisioningv1alpha1.ProvisioningRequest, message string)
SetProvisioningStateFailed updates the provisioning state to failed with detailed message
func SetProvisioningStateFulfilled ¶
func SetProvisioningStateFulfilled(cr *provisioningv1alpha1.ProvisioningRequest)
SetProvisioningStateFulfilled updates the provisioning state to fulfilled with detailed message
func SetProvisioningStateInProgress ¶
func SetProvisioningStateInProgress(cr *provisioningv1alpha1.ProvisioningRequest, message string)
SetProvisioningStateInProgress updates the provisioning state to progressing with detailed message
func SetStatusCondition ¶
func SetStatusCondition(existingConditions *[]metav1.Condition, conditionType ConditionType, conditionReason ConditionReason, conditionStatus metav1.ConditionStatus, message string)
SetStatusCondition is a convenience wrapper for meta.SetStatusCondition that takes in the types defined here and converts them to strings
func SetupOAuthClient ¶
SetupOAuthClient creates an HTTP client capable of acquiring an OAuth token used to authorize client requests. If the config excludes the OAuth specific sections then the client produced is a simple HTTP client without OAuth capabilities.
func TimeoutExceeded ¶
TimeoutExceeded returns true if it's been more time than the timeout configuration.
func UpdateHardwareTemplateStatusCondition ¶
func UpdateHardwareTemplateStatusCondition(ctx context.Context, c client.Client, hardwareTemplate *hwv1alpha1.HardwareTemplate, conditionType ConditionType, conditionReason ConditionReason, conditionStatus metav1.ConditionStatus, message string) error
UpdateHardwareTemplateStatusCondition updates the status condition of the HardwareTemplate resource
func UpdateK8sCRStatus ¶
func UpdateNodeStatusWithHostname ¶
func UpdateNodeStatusWithHostname(ctx context.Context, c client.Client, nodeName, hostname, namespace string) error
UpdateNodeStatusWithHostname updates the Node status with the hostname after BMC information has been assigned.
func ValidateDefaultInterfaces ¶
ValidateDefaultInterfaces verifies that each interface has a specified label field, as labels are not part of the ClusterInstance structure by default.
Types ¶
type AvailableNotification ¶
type AvailableNotification struct { GlobalCloudId string `json:"globalCloudId"` OCloudId string `json:"oCloudId"` ImsEndpoint string `json:"IMS_EP"` }
AvailableNotification represents the data sent to the SMO once the O2IMS is ready to accept API calls. This is from table 3.6.5.1.2-1 in the O-RAN.WG6.O2IMS-INTERFACE-R003-v06.00 document, and presumably will be formally defined in an OpenAPI that we can just import at some point.
type ConditionDoesNotExistsErr ¶
type ConditionDoesNotExistsErr struct {
ConditionName string
}
ConditionDoesNotExistsErr represents an error when a specific condition is missing
func (*ConditionDoesNotExistsErr) Error ¶
func (e *ConditionDoesNotExistsErr) Error() string
Error implements the error interface for ConditionDoesNotExistsErr, returning a formatted error message
type ConditionReason ¶
type ConditionReason string
ConditionReason is a string representing the condition's reason
type ConditionType ¶
type ConditionType string
ConditionType is a string representing the condition's type
type InputError ¶
type InputError struct {
// contains filtered or unexported fields
}
InputError wraps a standard error and provides a custom error type for input-related errors
func NewInputError ¶
func NewInputError(format string, args ...interface{}) *InputError
func (*InputError) Error ¶
func (i *InputError) Error() string
type InventoryConditionReason ¶
type InventoryConditionReason string
type InventoryConditionType ¶
type InventoryConditionType string
InventoryConditionType defines conditions of an Inventory deployment.
type NodeInfo ¶
type NodeInfo struct { BmcAddress string BmcCredentials string NodeName string Interfaces []*hwv1alpha1.Interface }
type OAuthClientConfig ¶
type OAuthClientConfig struct { // Defines a PEM encoded set of CA certificates used to validate server certificates. If not provided then the // default root CA bundle will be used. CaBundle []byte // Defines the OAuth client-id attribute to be used when acquiring a token. If not provided (for debug/testing) // then a normal HTTP client without OAuth capabilities will be created ClientId string ClientSecret string // The absolute URL of the API endpoint to be used to acquire a token // (e.g., http://example.com/realms/oran/protocol/openid-connect/token) TokenUrl string // The list of OAuth scopes requested by the client. These will be dictated by what the SMO is expecting to see in // the token. Scopes []string // The client certificate to be used when initiating connection to the server. ClientCert *tls.Certificate }
OAuthClientConfig defines the parameters required to establish an HTTP Client capable of acquiring an OAuth Token from an OAuth capable authorization server.