mirror of
https://github.com/redhat-developer/odo.git
synced 2025-10-19 03:06:19 +03:00
* Define central config * Use envConfig in GenericRun for segment parameters * Pass the env config into the context passed to CLI methods * Use PodmanCmd and DockerCmd from context * Remove tests now that ODO_DISABLE_TELEMETRY is checked for a bool value * deploy.Deploy: Use values from ctx instead of parameters + use FS from DI * dev.Start: Use values from ctx instead of parameters * image.Build*: Use values from ctx instead of parameters * Use telemetry file from context * Pass ctx to segment.getTelemetryForDevfileRegistry * Use ctx in getTelemetryForDevfileRegistry * Call IsTelemetryEnabled once and use scontext.GetTelemetryStatus after * Fix unit tests * Use envConfig in segment.IsTelemetryEnabled * Define TelemetryCaller constant in test helper * IsTrackingConsentEnabled: get value from envconfig instead of env * Use ctx instead of GLOBALODOCONFIG * Place ODO_EXPERIMENTAL_MODE in configuration * Use maintained envconfig package * Define default values when exist * Document accepted boolean values
58 lines
1.5 KiB
Go
Generated
58 lines
1.5 KiB
Go
Generated
// Copyright The envconfig Authors
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package envconfig
|
|
|
|
import (
|
|
"encoding/base64"
|
|
"encoding/hex"
|
|
"strings"
|
|
)
|
|
|
|
// Base64Bytes is a slice of bytes where the information is base64-encoded in
|
|
// the environment variable.
|
|
type Base64Bytes []byte
|
|
|
|
// EnvDecode implements env.Decoder.
|
|
func (b *Base64Bytes) EnvDecode(val string) error {
|
|
val = strings.ReplaceAll(val, "+", "-")
|
|
val = strings.ReplaceAll(val, "/", "_")
|
|
val = strings.TrimRight(val, "=")
|
|
|
|
var err error
|
|
*b, err = base64.RawURLEncoding.DecodeString(val)
|
|
return err
|
|
}
|
|
|
|
// Bytes returns the underlying bytes.
|
|
func (b Base64Bytes) Bytes() []byte {
|
|
return []byte(b)
|
|
}
|
|
|
|
// HexBytes is a slice of bytes where the information is hex-encoded in the
|
|
// environment variable.
|
|
type HexBytes []byte
|
|
|
|
// EnvDecode implements env.Decoder.
|
|
func (b *HexBytes) EnvDecode(val string) error {
|
|
var err error
|
|
*b, err = hex.DecodeString(val)
|
|
return err
|
|
}
|
|
|
|
// Bytes returns the underlying bytes.
|
|
func (b HexBytes) Bytes() []byte {
|
|
return []byte(b)
|
|
}
|