forked from google/localtoast
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlocaltoast.go
82 lines (70 loc) · 2.88 KB
/
localtoast.go
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
// Copyright 2021 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// The localtoast command wraps around the scanner library to create a standalone
// CLI for the config scanner with direct access to the local machine's filesystem.
package main
import (
"context"
"errors"
"io"
"os"
"path"
"runtime/debug"
"github.com/google/localtoast/localfilereader"
"github.com/google/localtoast/scanapi"
"github.com/google/localtoast/scannercommon"
apb "github.com/google/localtoast/scannerlib/proto/api_go_proto"
ipb "github.com/google/localtoast/scannerlib/proto/scan_instructions_go_proto"
)
// localScanAPIProvider provides access to the local filesystem.
type localScanAPIProvider struct {
chrootPath string
}
func (a *localScanAPIProvider) fullPath(entryPath string) string {
if a.chrootPath == "" {
return entryPath
}
return path.Join(a.chrootPath, entryPath)
}
func (a *localScanAPIProvider) OpenFile(ctx context.Context, filePath string) (io.ReadCloser, error) {
return localfilereader.OpenFile(ctx, a.fullPath(filePath))
}
func (a *localScanAPIProvider) OpenDir(ctx context.Context, path string) (scanapi.DirReader, error) {
return localfilereader.OpenDir(ctx, a.fullPath(path))
}
func (a *localScanAPIProvider) FilePermissions(ctx context.Context, filePath string) (*apb.PosixPermissions, error) {
return localfilereader.FilePermissions(ctx, a.fullPath(filePath))
}
func (localScanAPIProvider) SQLQuery(ctx context.Context, query string) (int, error) {
// This is intentionally not implemented for the scanner version without SQL.
return 0, errors.New("not implemented")
}
func (localScanAPIProvider) SQLQueryWithResponse(ctx context.Context, query string) (string, error) {
// This is intentionally not implemented for the scanner version without SQL.
return "", errors.New("not implemented")
}
func (localScanAPIProvider) SupportedDatabase() (ipb.SQLCheck_SQLDatabase, error) {
// This is intentionally not implemented for the scanner version without SQL.
return ipb.SQLCheck_DB_UNSPECIFIED, errors.New("not implemented")
}
func main() {
// Change GCPercent to lower the peak memory usage.
// Make sure we are not overwriting a custom value. We only want to change the default.
if os.Getenv("GOGC") == "" {
debug.SetGCPercent(1)
}
flags := scannercommon.ParseFlags()
provider := &localScanAPIProvider{chrootPath: flags.ChrootPath}
os.Exit(scannercommon.RunScan(flags, provider))
}