Documentation
¶
Index ¶
- Constants
- func ConvertJWKToPEM(jwkJSON string) ([]byte, error)
- func ConvertPEMToJWK(pemData string) (string, error)
- func CopyDir(src, dst string) error
- func CopyFile(src, dst string) error
- func FirstOrDash(items ...string) string
- func FormatLocal(t time.Time) string
- func GetKernelClient(cmd *cobra.Command) kernel.Client
- func IsNotFound(err error) bool
- func IsPEMKey(data string) bool
- func JoinOrDash(items ...string) string
- func ModifyFile(path, oldStr, newStr string) error
- func NewClient(opts ...option.RequestOption) kernel.Client
- func OrDash(s string) string
- func PrintPrettyJSON(v RawJSONProvider) error
- func PrintPrettyJSONSlice[T RawJSONProvider](items []T) error
- func Unzip(zipFilePath, destDir string) error
- func ValidatePEMKey(pemData string) error
- func ZipDirectory(srcDir, destZip string) error
- type CleanedUpSdkError
- type ContextKey
- type RawJSONProvider
Constants ¶
const DefaultTimeLayout = "2006-01-02 15:04:05 MST"
DefaultTimeLayout is the standard layout used for displaying timestamps. Includes the local timezone abbreviation to make it clear times are local.
Variables ¶
This section is empty.
Functions ¶
func ConvertJWKToPEM ¶ added in v0.13.4
ConvertJWKToPEM converts an Ed25519 JWK to PEM format
func ConvertPEMToJWK ¶ added in v0.13.4
ConvertPEMToJWK converts an Ed25519 PEM private key to JWK format
func FirstOrDash ¶
FirstOrDash returns the first non-empty string from the provided items. If all items are empty, it returns "-".
func FormatLocal ¶
FormatLocal formats the provided time in the user's local timezone. If the time is zero, it returns "-".
func GetKernelClient ¶
GetKernelClient retrieves the kernel client from the command context
func IsNotFound ¶
IsNotFound returns true if the error is a Kernel API error with HTTP 404.
func JoinOrDash ¶
JoinOrDash joins the provided strings with ", " as separator. If no items are provided, it returns "-".
func ModifyFile ¶ added in v0.13.4
ModifyFile replaces all occurrences of oldStr with newStr in the file. Returns an error if the pattern is not found in the file
func NewClient ¶
func NewClient(opts ...option.RequestOption) kernel.Client
NewClient returns a kernel API client preconfigured with middleware that detects when a newer CLI/SDK version is required and informs the user.
It mirrors kernel.NewClient but injects an HTTP middleware that intercepts 400 responses with error codes "sdk_upgrade_required" or "sdk_update_required". When encountered, a helpful upgrade message is displayed once per process.
func PrintPrettyJSON ¶ added in v0.13.4
func PrintPrettyJSON(v RawJSONProvider) error
PrintPrettyJSON prints the raw JSON from an SDK response type with indentation. It uses the RawJSON() method to get the original API response, avoiding zero-value fields that would appear when re-marshaling the Go struct.
func PrintPrettyJSONSlice ¶ added in v0.13.4
func PrintPrettyJSONSlice[T RawJSONProvider](items []T) error
PrintPrettyJSONSlice prints a slice of SDK response types as a JSON array. Each element must implement RawJSONProvider.
func ValidatePEMKey ¶ added in v0.13.4
ValidatePEMKey validates that a PEM-encoded string contains a valid Ed25519 private key
func ZipDirectory ¶
ZipDirectory compresses the given source directory into the destination file path.
Types ¶
type CleanedUpSdkError ¶
type CleanedUpSdkError struct {
Err error
}
CleanedUpSdkError extracts a message field from the raw JSON resposne. This is the convention we use in the API for error response bodies (400s and 500s)
func (CleanedUpSdkError) Error ¶
func (e CleanedUpSdkError) Error() string
func (CleanedUpSdkError) Unwrap ¶
func (e CleanedUpSdkError) Unwrap() error
type ContextKey ¶
type ContextKey string
ContextKey is the type for context keys
const KernelClientKey ContextKey = "kernel_client"
KernelClientKey is the context key for the kernel client
type RawJSONProvider ¶ added in v0.13.4
type RawJSONProvider interface {
RawJSON() string
}
RawJSONProvider is an interface for SDK types that provide raw JSON responses.