Documentation ¶
Index ¶
- Constants
- Variables
- func AddAuthDetails(req *http.Request, filepath string) error
- func AddContextToConfig(contextName string, context config.Context, configPath string, set bool) error
- func AddTokenToConfig(token config.Token, configPath string) error
- func ApplyManifest(manifest []byte, client *meshkitkube.Client, update bool, delete bool) error
- func ApplyManifestFiles(manifestArr []Manifest, requestedAdapters []string, client *meshkitkube.Client, ...) error
- func ApplyOperatorManifest(client *meshkitkube.Client, update bool, delete bool) error
- func AskForConfirmation(s string) bool
- func AskForInput(prompt string, allowed []string) string
- func ChangeConfigEndpoint(currCtx string, ctx config.Context) error
- func ChangeContextVersion(contextName, version string) error
- func ChangeManifestVersion(fileName string, channel string, version string, filePath string) error
- func ChangePlatform(currCtx string, ctx config.Context) error
- func CheckK8sVersion(versionInfo *version.Info) error
- func CheckKubectlVersion() error
- func CleanPodNames(name string) string
- func ContentTypeIsHTML(resp *http.Response) bool
- func CreateConfigFile() error
- func CreateDefaultSpinner(suffix string, finalMsg string) *spinner.Spinner
- func CreateManifestsFolder() error
- func DownloadDockerComposeFile(ctx config.Context, force bool) error
- func DownloadFile(filepath string, url string) error
- func DownloadManifests(manifestArr []Manifest, rawManifestsURL string) error
- func DownloadOperatorManifest() error
- func GenerateConfigAKS(configPath, resourceGroup, clusterName string) error
- func GenerateConfigEKS(configPath, region, cluster string) error
- func GenerateConfigGKE(configPath, SAName, namespc string) error
- func GenerateConfigMinikube(configPath string) error
- func GetK8sVersionInfo() (*version.Info, error)
- func GetLatestStableReleaseTag() (string, error)
- func GetManifestTreeURL(version string) (string, error)
- func GetManifestURL(manifest Manifest, rawManifestsURL string) string
- func GetPods(client *meshkitkube.Client, namespace string) (*v1core.PodList, error)
- func GetRequiredPods(specifiedPods []string, availablePods []v1core.Pod) ([]string, error)
- func InstallprereqDocker() error
- func IsAdapterValid(manifestArr []Manifest, adapterManifest string) bool
- func IsMesheryRunning(currPlatform string) (bool, error)
- func IsPodRequired(requiredPods []string, pod string) bool
- func IsValidSubcommand(available []*cobra.Command, sub string) bool
- func NavigateToBrowser(endpoint string) error
- func PerfError(msg string) string
- func PrintToTable(header []string, data [][]string)
- func PrintToTableWithFooter(header []string, data [][]string, footer []string)
- func ReadToken(filepath string) (map[string]string, error)
- func RootError(msg string) string
- func SafeClose(co io.Closer)
- func SetFileLocation() error
- func Startdockerdaemon(subcommand string) error
- func StringContainedInSlice(str string, slice []string) int
- func StringInSlice(str string, slice []string) bool
- func StringWithCharset(length int) string
- func SystemError(msg string) string
- func TruncateID(id string) string
- func UpdateAuthDetails(filepath string) error
- func UpdateMesheryContainers() error
- func UploadFileWithParams(uri string, params map[string]string, paramName, path string) (*http.Request, error)
- func ValidateURL(URL string) error
- type Containers
- type DockerCompose
- type K8sCompose
- type Manifest
- type ManifestList
- type OnlyStringFormatterForLogrus
- type Service
- type Spec
- type Template
- type TemplateSpec
- type Volumes
Constants ¶
const ( OperatorURL = baseConfigURL + "manifests/default.yaml" BrokerURL = baseConfigURL + "samples/meshery_v1alpha1_broker.yaml" MeshsyncURL = baseConfigURL + "samples/meshery_v1alpha1_meshsync.yaml" // Meshery Server Location EndpointProtocol = "http" )
Variables ¶
var ( // ResetFlag indicates if a reset is required ResetFlag bool // SkipResetFlag indicates if fetching the updated manifest files is required SkipResetFlag bool // MesheryEndpoint is the default URL in which Meshery is exposed MesheryEndpoint = "http://localhost:9081" // MesheryFolder is the default relative location of the meshery config // related configuration files. MesheryFolder = ".meshery" // DockerComposeFile is the default location within the MesheryFolder // where the docker compose file is located. DockerComposeFile = "meshery.yaml" // AuthConfigFile is the location of the auth file for performing perf testing AuthConfigFile = "auth.json" // DefaultConfigPath is the detail path to mesheryctl config DefaultConfigPath = "config.yaml" // MesheryNamespace is the namespace to which Meshery is deployed in the Kubernetes cluster MesheryNamespace = "meshery" // MesheryDeployment is the name of a Kubernetes manifest file required to setup Meshery // check https://github.com/layer5io/meshery/tree/master/install/deployment_yamls/k8s MesheryDeployment = "meshery-deployment.yaml" // MesheryService is the name of a Kubernetes manifest file required to setup Meshery // check https://github.com/layer5io/meshery/tree/master/install/deployment_yamls/k8s MesheryService = "meshery-service.yaml" //MesheryOperator is the file for default Meshery operator //check https://github.com/layer5io/meshery-operator/blob/master/config/manifests/default.yaml MesheryOperator = "default.yaml" //MesheryOperatorBroker is the file for the Meshery broker //check https://github.com/layer5io/meshery-operator/blob/master/config/samples/meshery_v1alpha1_broker.yaml MesheryOperatorBroker = "meshery_v1alpha1_broker.yaml" //MesheryOperatorMeshsync is the file for the Meshery Meshsync Operator //check https://github.com/layer5io/meshery-operator/blob/master/config/samples/meshery_v1alpha1_meshsync.yaml MesheryOperatorMeshsync = "meshery_v1alpha1_meshsync.yaml" // ServiceAccount is the name of a Kubernetes manifest file required to setup Meshery // check https://github.com/layer5io/meshery/tree/master/install/deployment_yamls/k8s ServiceAccount = "service-account.yaml" // ViperCompose is an instance of viper for docker-compose ViperCompose = viper.New() // ViperDocker is an instance of viper for the meshconfig file when the platform is docker ViperDocker = viper.New() // ViperK8s is an instance of viper for the meshconfig file when the platform is kubernetes ViperK8s = viper.New() // SilentFlag skips waiting for user input and proceeds with default options SilentFlag bool // PlatformFlag sets the platform for the initial config file PlatformFlag string )
var ListOfAdapters = []string{"meshery-istio", "meshery-linkerd", "meshery-consul", "meshery-nsm", "meshery-kuma", "meshery-cpx", "meshery-osm", "meshery-traefik-mesh"}
ListOfAdapters returns the list of adapters available
var (
// ManifestsFolder is where the Kubernetes manifests are stored
ManifestsFolder = "manifests"
)
var TemplateContext = config.Context{ Endpoint: EndpointProtocol + "://localhost:9081", Token: "Default", Platform: "docker", Adapters: ListOfAdapters, Channel: "stable", Version: "latest", }
TemplateContext is the template context provided when creating a config file
var TemplateToken = config.Token{ Name: "Default", Location: AuthConfigFile, }
TemplateToken is the template token provided when creating a config file
Functions ¶
func AddAuthDetails ¶
AddAuthDetails Adds authentication cookies to the request
func AddContextToConfig ¶ added in v0.5.1
func AddContextToConfig(contextName string, context config.Context, configPath string, set bool) error
AddContextToConfig adds context passed to it to mesheryctl config file
func AddTokenToConfig ¶ added in v0.5.2
AddTokenToConfig adds token passed to it to mesheryctl config file
func ApplyManifest ¶ added in v0.5.2
ApplyManifest is a wrapper function for client.ApplyManifest
func ApplyManifestFiles ¶ added in v0.5.2
func ApplyManifestFiles(manifestArr []Manifest, requestedAdapters []string, client *meshkitkube.Client, update bool, delete bool) error
ApplyManifestFiles applies/updates/deletes all the required manifests into the Kubernetes cluster
func ApplyOperatorManifest ¶ added in v0.5.12
func ApplyOperatorManifest(client *meshkitkube.Client, update bool, delete bool) error
ApplyOperatorManifest applies/updates/deletes the operator manifest
func AskForConfirmation ¶ added in v0.5.1
AskForConfirmation asks the user for confirmation. A user must type in "yes" or "no" and then press enter. It has fuzzy matching, so "y", "Y", "yes", "YES", and "Yes" all count as confirmations. If the input is not recognized, it will ask again. The function does not return until it gets a valid response from the user.
func AskForInput ¶ added in v0.5.15
AskForInput asks the user for an input and checks if it is in the available values
func ChangeConfigEndpoint ¶ added in v0.5.14
ChangeConfigEndpoint changes the endpoint of the current context in meshconfig, based on the platform
func ChangeContextVersion ¶ added in v0.5.18
ChangeContextVersion changes the version of the specified context to the specified version
func ChangeManifestVersion ¶ added in v0.5.3
ChangeManifestVersion changes the tag of the images in the manifest according to the pinned version
func ChangePlatform ¶ added in v0.5.19
ChangePlatform changes the platform specified in the current context to the specified platform
func CheckK8sVersion ¶ added in v0.5.3
func CheckKubectlVersion ¶ added in v0.5.3
func CheckKubectlVersion() error
CheckKubectlVersion validates whether the installed kubectl version is running a minimum kubectl version.
func CleanPodNames ¶ added in v0.5.13
CleanPodNames cleans the pod names in the MesheryNamespace to make it more readable
func ContentTypeIsHTML ¶ added in v0.3.18
ContentTypeIsHTML Checks if the response is an HTML resposnse
func CreateConfigFile ¶ added in v0.5.1
func CreateConfigFile() error
CreateConfigFile creates config file in Meshery Folder
func CreateDefaultSpinner ¶ added in v0.5.24
func CreateManifestsFolder ¶ added in v0.5.13
func CreateManifestsFolder() error
CreateManifestsFolder creates a new folder (.meshery/manifests)
func DownloadDockerComposeFile ¶ added in v0.5.1
DownloadDockerComposeFile fetches docker-compose.yaml based on passed context if it does not exists. Use force to override download anyway
func DownloadFile ¶
DownloadFile from url and save to configured file location
func DownloadManifests ¶ added in v0.5.1
DownloadManifests downloads all the Kubernetes manifest files
func DownloadOperatorManifest ¶ added in v0.5.13
func DownloadOperatorManifest() error
DownloadOperatorManifest downloads the operator manifest files
func GenerateConfigAKS ¶ added in v0.5.1
GenerateConfigAKS generates kube config file in ~/.meshery/kubeconfig.yaml for a AKS cluster
func GenerateConfigEKS ¶ added in v0.5.1
GenerateConfigEKS generates kube config file in .meshery/kubeconfig.yaml for an EKS cluster
func GenerateConfigGKE ¶
GenerateConfigGKE generates kube config file in ~/.meshery/kubeconfig.yaml for a GKE cluster
func GenerateConfigMinikube ¶
GenerateConfigMinikube generates kube config file in ~/.meshery/kubeconfig.yaml for a Minikube cluster
func GetK8sVersionInfo ¶ added in v0.5.3
GetK8sVersionInfo returns version.Info for the Kubernetes cluster.
func GetLatestStableReleaseTag ¶ added in v0.5.1
GetLatestStableReleaseTag fetches and returns the latest release tag from GitHub
func GetManifestTreeURL ¶ added in v0.5.2
GetManifestTreeURL returns the manifest tree url based on version
func GetManifestURL ¶ added in v0.5.1
GetManifestURL returns the URLs for the manifest files
func GetRequiredPods ¶ added in v0.5.13
GetRequiredPods checks if the pods specified by the user is valid returns a list of the required pods
func InstallprereqDocker ¶ added in v0.5.12
func InstallprereqDocker() error
func IsAdapterValid ¶ added in v0.5.1
IsAdapterValid checks if the adapter mentioned by the user is a valid adapter
func IsMesheryRunning ¶
IsMesheryRunning checks if the meshery server containers are up and running
func IsPodRequired ¶ added in v0.5.13
IsPodRequired checks if a given pod is specified in the required pods
func IsValidSubcommand ¶
IsValidSubcommand checks if the passed subcommand is supported by the parent command
func NavigateToBrowser ¶ added in v0.5.12
NavigateToBroswer naviagtes to the endpoint displaying Meshery UI in the broswer, based on the host operating system.
func PerfError ¶
PerfError returns a formatted error message with a link to 'perf' command usage page at in addition to the error message
func PrintToTable ¶ added in v0.5.2
PrintToTable prints the given data into a table format
func PrintToTableWithFooter ¶ added in v0.5.11
PrintToTableWithFooter prints the given data into a table format but with a footer
func RootError ¶
RootError returns a formatted error message with a link to 'root' command usage page at in addition to the error message
func Startdockerdaemon ¶ added in v0.5.12
func StringContainedInSlice ¶ added in v0.5.13
StringContainedInSlice returns the index in which a string is a substring in a list of strings
func StringInSlice ¶ added in v0.5.15
StringInSlice checks if a string is present in a slice
func StringWithCharset ¶
StringWithCharset generates a random string with a given length
func SystemError ¶
SystemError returns a formatted error message with a link to 'system' command usage page in addition to the error message
func TruncateID ¶ added in v0.5.11
TruncateID shortens an id to 8 characters
func UpdateAuthDetails ¶
UpdateAuthDetails checks gets the token (old/refreshed) from meshery server and writes it back to the config file
func UpdateMesheryContainers ¶ added in v0.5.1
func UpdateMesheryContainers() error
UpdateMesheryContainers runs the update command for meshery client
func UploadFileWithParams ¶
func UploadFileWithParams(uri string, params map[string]string, paramName, path string) (*http.Request, error)
UploadFileWithParams returns a request configured to upload files with other values
func ValidateURL ¶ added in v0.5.1
ValidateURL validates url provided for meshery backend to mesheryctl context
Types ¶
type Containers ¶ added in v0.5.3
type DockerCompose ¶ added in v0.5.1
type K8sCompose ¶ added in v0.5.3
type Manifest ¶ added in v0.5.1
type Manifest struct { Path string `json:"path,omitempty"` Mode string `json:"mode,omitempty"` Typ string `json:"type,omitempty"` SHA string `json:"sha,omitempty"` Size json.Number `json:"size,omitempty"` URL string `json:"url,omitempty"` }
func FetchManifests ¶ added in v0.5.2
FetchManifests is a wrapper function that identifies the required manifest files as downloads them
func ListManifests ¶ added in v0.5.1
ListManifests lists the manifest files stored in GitHub
type ManifestList ¶ added in v0.5.1
type OnlyStringFormatterForLogrus ¶ added in v0.5.1
type OnlyStringFormatterForLogrus struct{}
OnlyStringFormatterForLogrus is a custom logrus formatter that returns only string of message as output
type Template ¶ added in v0.5.3
type Template struct { Metadata interface{} `yaml:"metadata,omitempty"` Spec TemplateSpec `yaml:"spec,omitempty"` }
type TemplateSpec ¶ added in v0.5.3
type TemplateSpec struct { ServiceAccount string `yaml:"serviceAccount,omitempty"` Containers []Containers `yaml:"containers,omitempty"` RestartPolicy string `yaml:"restartPolicy,omitempty"` }