forked from cloudquery/cloudquery
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathquery.go
More file actions
40 lines (35 loc) · 1.49 KB
/
query.go
File metadata and controls
40 lines (35 loc) · 1.49 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
package cmd
import (
"github.com/cloudquery/cloudquery/cloudqueryclient"
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
var queryCmd = &cobra.Command{
Use: "query",
Short: "Run queries specified in a policy file",
Version: Version,
RunE: func(cmd *cobra.Command, args []string) error {
viper.BindPFlag("dsn", cmd.Flags().Lookup("dsn"))
viper.BindPFlag("driver", cmd.Flags().Lookup("driver"))
driver := viper.GetString("driver")
dsn := viper.GetString("dsn")
queryConfigPath := viper.GetString("policy_path")
queryOutputJsonPath := viper.GetString("output")
client, err := cloudqueryclient.New(driver, dsn, verbose)
if err != nil {
return err
}
return client.RunQuery(queryConfigPath, queryOutputJsonPath)
},
}
func init() {
queryCmd.Flags().String("dsn", "./cloudquery.db", "database connection string or filepath if driver is sqlite (env CQ_DSN)")
queryCmd.Flags().String("driver", "sqlite", "database driver sqlite/postgresql/mysql/sqlserver (env CQ_DRIVER)")
queryCmd.Flags().String("path", "./policy.yml", "path to a policy file. can be generated with 'gen policy' command (env CQ_POLICY_PATH)")
queryCmd.Flags().String("output", "", "output path to store results as json file (env CQ_OUTPUT)")
viper.BindPFlag("dsn", queryCmd.Flags().Lookup("dsn"))
viper.BindPFlag("driver", queryCmd.Flags().Lookup("driver"))
viper.BindPFlag("policy_path", queryCmd.Flags().Lookup("path"))
viper.BindPFlag("output", queryCmd.Flags().Lookup("output"))
rootCmd.AddCommand(queryCmd)
}