Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var AddCanary = &cobra.Command{ Use: "canary <system.yaml>", Short: "Add a new canary spec", Run: func(cmd *cobra.Command, configFiles []string) { if err := configSync.SyncCanary(dataFile, configFiles...); err != nil { logger.Fatalf("Could not sync canaries: %v", err) } }, }
View Source
var AddTopology = &cobra.Command{ Use: "topology <system.yaml>", Short: "Add a new topology spec", Run: func(cmd *cobra.Command, configFiles []string) { opts := getTopologyRunOptions(0) if err := configSync.SyncTopology(opts, dataFile, configFiles...); err != nil { logger.Fatalf("Could not sync topology: %v", err) } }, }
View Source
var Docs = &cobra.Command{ Use: "docs", Short: "Generate docs ", Hidden: true, Args: cobra.MinimumNArgs(0), Run: func(cmd *cobra.Command, args []string) { printAPIDocs(args) }, }
View Source
var Operator = &cobra.Command{
Use: "operator",
Short: "Start the kubernetes operator",
Run: run,
}
View Source
var QueryTopology = &cobra.Command{ Use: "query", Short: "Query the topology", Args: cobra.MinimumNArgs(0), Run: func(cmd *cobra.Command, args []string) { if !db.IsConfigured() { logger.Fatalf("Must specify --db or DB_URL env") } if err := db.Init(); err != nil { logger.Fatalf("error connecting with postgres %v", err) } results, err := topology.Query(queryParams) if err != nil { logger.Fatalf("Failed to query topology: %v", err) } data, _ := json.MarshalIndent(results, "", " ") fmt.Println(string(data)) }, }
View Source
var Root = &cobra.Command{ Use: "canary-checker", PersistentPreRun: func(cmd *cobra.Command, args []string) { logger.UseZap(cmd.Flags()) for _, script := range sharedLibrary { if err := templating.LoadSharedLibrary(script); err != nil { logger.Errorf("Failed to load shared library %s: %v", script, err) } } db.ConnectionString = readFromEnv(db.ConnectionString) }, }
View Source
var Run = &cobra.Command{ Use: "run <canary.yaml>", Short: "Execute checks and return", Run: func(cmd *cobra.Command, configFiles []string) { timer := timer.NewTimer() if len(configFiles) == 0 { log.Fatalln("Must specify at least one canary") } kommonsClient, err := pkg.NewKommonsClient() if err != nil { logger.Warnf("Failed to get kommons client, features that read kubernetes configs will fail: %v", err) } var results = []*pkg.CheckResult{} wg := sync.WaitGroup{} queue := make(chan []*pkg.CheckResult, 1) for _, configfile := range configFiles { configs, err := pkg.ParseConfig(configfile, dataFile) if err != nil { logger.Errorf("Could not parse %s: %v", configfile, err) continue } logger.Infof("Checking %s, %d checks found", configfile, len(configs)) for _, config := range configs { if namespace != "" { config.Namespace = namespace } if config.Name == "" { config.Name = CleanupFilename(configfile) } wg.Add(1) _config := config go func() { queue <- checks.RunChecks(context.New(kommonsClient, _config)) wg.Done() }() } } failed := 0 passed := 0 go func() { wg.Wait() close(queue) }() for item := range queue { for _, result := range item { if !result.Pass { failed++ } else { passed++ } fmt.Printf("%s \t%s\t\n", time.Now().Format(time.RFC3339), result.String()) results = append(results, result) } } if junit { report := output.GetJunitReport(results) if err := output.HandleOutput(report, outputFile); err != nil { logger.Fatalf("error writing output file: %v", err) } } if csv { report, err := output.GetCSVReport(results) if err != nil { logger.Fatalf("error generating CSV file: %v", err) } if err := output.HandleOutput(report, outputFile); err != nil { logger.Fatalf("error writing output file: %v", err) } } logger.Infof("%d passed, %d failed in %s", passed, failed, timer) if failed > 0 { os.Exit(1) } }, }
View Source
var RunTopology = &cobra.Command{ Use: "run <system.yaml>", Short: "Execute topology and return", Run: func(cmd *cobra.Command, configFiles []string) { timer := timer.NewTimer() if len(configFiles) == 0 { log.Fatalln("Must specify at least one topology definition") } opts := getTopologyRunOptions(10) var results = []*pkg.System{} wg := sync.WaitGroup{} for _, configfile := range configFiles { configs, err := pkg.ParseSystems(configfile, dataFile) if err != nil { logger.Errorf("Could not parse %s: %v", configfile, err) continue } logger.Infof("Checking %s, %d systems found", configfile, len(configs)) for _, config := range configs { wg.Add(1) _config := config go func() { systems := topology.Run(opts, _config) results = append(results, systems...) wg.Done() }() } } wg.Wait() logger.Infof("Checked %d systems in %v", len(results), timer) if db.IsConnected() { if err := db.PersistSystems(results); err != nil { logger.Errorf("error persisting results: %v", err) } return } data, _ := json.Marshal(results) if outputFile == "" { outputFile = "topology.json" } logger.Infof("Writing results to %s", outputFile) if err := ioutil.WriteFile(outputFile, data, 0644); err != nil { log.Fatalln(err) } }, }
View Source
var Serve = &cobra.Command{ Use: "serve config.yaml", Short: "Start a server to execute checks", Run: func(cmd *cobra.Command, configFiles []string) { setup() controllers.StartScanCanaryConfigs(dataFile, configFiles) if executor { controllers.Start() } serve() }, }
Functions ¶
func CleanupFilename ¶ added in v0.33.0
func ParseDocumentationFrom ¶
ParseDocumentationFrom gets all types' documentation and returns them as an array. Each type is again represented as an array (we have to use arrays as we need to be sure for the order of the fields). This function returns fields and struct definitions that have no documentation as {name, ""}.
func ServerFlags ¶ added in v0.38.4
Types ¶
type Struct ¶
type Struct struct {
Name, Doc string
StructType *ast.StructType
DocType *doc.Type
Fields StructFields
}
type StructField ¶
func NewStructField ¶
func NewStructField(field *ast.Field) StructField
func (StructField) MarkdownRow ¶ added in v0.38.32
func (f StructField) MarkdownRow(structs map[string]*Struct) string
type StructFields ¶ added in v0.38.32
type StructFields []StructField
func (StructFields) GetAllFields ¶ added in v0.38.32
func (s StructFields) GetAllFields(structs map[string]*Struct) StructFields
func (StructFields) Len ¶ added in v0.38.32
func (s StructFields) Len() int
func (StructFields) Less ¶ added in v0.38.32
func (s StructFields) Less(i, j int) bool
func (StructFields) Swap ¶ added in v0.38.32
func (s StructFields) Swap(i, j int)
Source Files ¶
Click to show internal directories.
Click to hide internal directories.