forked from hyperledger/fabric
-
Notifications
You must be signed in to change notification settings - Fork 3
/
ioutil.go
94 lines (83 loc) · 2.44 KB
/
ioutil.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
83
84
85
86
87
88
89
90
91
92
93
94
/*
Copyright IBM Corp. All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
package util
import (
"io"
"io/ioutil"
"os"
"path"
"strings"
"github.com/hyperledger/fabric/common/flogging"
"github.com/pkg/errors"
)
var logger = flogging.MustGetLogger("kvledger.util")
// CreateDirIfMissing creates a dir for dirPath if not already exists. If the dir is empty it returns true
func CreateDirIfMissing(dirPath string) (bool, error) {
// if dirPath does not end with a path separator, it leaves out the last segment while creating directories
if !strings.HasSuffix(dirPath, "/") {
dirPath = dirPath + "/"
}
logger.Debugf("CreateDirIfMissing [%s]", dirPath)
logDirStatus("Before creating dir", dirPath)
err := os.MkdirAll(path.Dir(dirPath), 0755)
if err != nil {
logger.Debugf("Error creating dir [%s]", dirPath)
return false, errors.Wrapf(err, "error creating dir [%s]", dirPath)
}
logDirStatus("After creating dir", dirPath)
return DirEmpty(dirPath)
}
// DirEmpty returns true if the dir at dirPath is empty
func DirEmpty(dirPath string) (bool, error) {
f, err := os.Open(dirPath)
if err != nil {
logger.Debugf("Error opening dir [%s]: %+v", dirPath, err)
return false, errors.Wrapf(err, "error opening dir [%s]", dirPath)
}
defer f.Close()
_, err = f.Readdir(1)
if err == io.EOF {
return true, nil
}
err = errors.Wrapf(err, "error checking if dir [%s] is empty", dirPath)
return false, err
}
// FileExists checks whether the given file exists.
// If the file exists, this method also returns the size of the file.
func FileExists(filePath string) (bool, int64, error) {
fileInfo, err := os.Stat(filePath)
if os.IsNotExist(err) {
return false, 0, nil
}
if err != nil {
return false, 0, errors.Wrapf(err, "error checking if file [%s] exists", filePath)
}
return true, fileInfo.Size(), nil
}
// ListSubdirs returns the subdirectories
func ListSubdirs(dirPath string) ([]string, error) {
subdirs := []string{}
files, err := ioutil.ReadDir(dirPath)
if err != nil {
return nil, errors.Wrapf(err, "error reading dir %s", dirPath)
}
for _, f := range files {
if f.IsDir() {
subdirs = append(subdirs, f.Name())
}
}
return subdirs, nil
}
func logDirStatus(msg string, dirPath string) {
exists, _, err := FileExists(dirPath)
if err != nil {
logger.Errorf("Error checking for dir existence")
}
if exists {
logger.Debugf("%s - [%s] exists", msg, dirPath)
} else {
logger.Debugf("%s - [%s] does not exist", msg, dirPath)
}
}