fleet/orbit/pkg/table/extension_linux.go

53 lines
2.4 KiB
Go
Raw Normal View History

2023-11-02 02:11:35 +00:00
//go:build linux
package table
import (
"context"
"github.com/fleetdm/fleet/v4/orbit/pkg/table/containerd"
2023-11-02 02:11:35 +00:00
"github.com/fleetdm/fleet/v4/orbit/pkg/table/crowdstrike/falcon_kernel_check"
"github.com/fleetdm/fleet/v4/orbit/pkg/table/crowdstrike/falconctl"
"github.com/fleetdm/fleet/v4/orbit/pkg/table/cryptsetup"
"github.com/fleetdm/fleet/v4/orbit/pkg/table/cryptsetup_luks_salt"
"github.com/fleetdm/fleet/v4/orbit/pkg/table/dataflattentable"
"github.com/fleetdm/fleet/v4/orbit/pkg/table/dconf_read"
"github.com/fleetdm/fleet/v4/orbit/pkg/table/fleetd_pacman_packages"
"github.com/macadmins/osquery-extension/tables/crowdstrike_falcon"
2023-11-02 02:11:35 +00:00
"github.com/osquery/osquery-go"
"github.com/osquery/osquery-go/plugin/table"
"github.com/rs/zerolog/log"
2023-11-02 02:11:35 +00:00
)
func PlatformTables(opts PluginOpts) ([]osquery.OsqueryPlugin, error) {
2023-11-02 02:11:35 +00:00
return []osquery.OsqueryPlugin{
cryptsetup.TablePlugin(log.Logger), // table name is "cryptsetup_status"
falconctl.NewFalconctlOptionTable(log.Logger), // table name is "falconctl_option"
falcon_kernel_check.TablePlugin(log.Logger), // table name is "falcon_kernel_check"
dataflattentable.TablePluginExec(log.Logger, "nftables", dataflattentable.JsonType, []string{"nft", "-jat", "list", "ruleset"}, dataflattentable.WithBinDirs("/usr/bin", "/usr/sbin")), // -j (json) -a (show object handles) -t (terse, omit set contents)
table.NewPlugin("dconf_read", dconf_read.Columns(), dconf_read.Generate),
table.NewPlugin("containerd_containers", containerd.ContainersColumns(), containerd.GenerateContainers),
table.NewPlugin("containerd_mounts", containerd.MountsColumns(), containerd.GenerateMounts),
table.NewPlugin(fleetd_pacman_packages.TableName, fleetd_pacman_packages.Columns(), fleetd_pacman_packages.Generate),
table.NewPlugin("crowdstrike_falcon", crowdstrike_falcon.CrowdstrikeFalconColumns(),
func(ctx context.Context, queryContext table.QueryContext) ([]map[string]string, error) {
return crowdstrike_falcon.CrowdstrikeFalconGenerate(ctx, queryContext, opts.Socket)
},
),
dataflattentable.TablePluginExec(
log.Logger,
"lsblk",
dataflattentable.JsonType,
[]string{"lsblk", "-n", "-O", "--json"}, // -n (no header) -O (all vars) --json (output in json)
dataflattentable.WithBinDirs("/usr/bin", "/usr/sbin"),
),
table.NewPlugin(
cryptsetup_luks_salt.TblName,
cryptsetup_luks_salt.Columns(),
cryptsetup_luks_salt.Generate,
),
}, nil
2023-11-02 02:11:35 +00:00
}