/
util.go
89 lines (75 loc) · 2.75 KB
/
util.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
/*
Copyright 2017 The Rook Authors. All rights reserved.
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.
*/
package util
import (
"io/ioutil"
"net"
"os"
"path/filepath"
"strconv"
"strings"
"github.com/coreos/pkg/capnslog"
"github.com/pkg/errors"
)
const (
RBDSysBusPathDefault = "/sys/bus/rbd"
RBDDevicesDir = "devices"
RBDDevicePathPrefix = "/dev/rbd"
)
var logger = capnslog.NewPackageLogger("github.com/rook/rook", "op-ceph-util")
// FindRBDMappedFile search for the mapped RBD volume and returns its device path
func FindRBDMappedFile(imageName, poolName, sysBusDir string) (string, error) {
sysBusDeviceDir := filepath.Join(sysBusDir, RBDDevicesDir)
// if sysPath does not exist, no attachments has happened
if _, err := os.Stat(sysBusDeviceDir); os.IsNotExist(err) {
return "", nil
}
files, err := ioutil.ReadDir(sysBusDeviceDir)
if err != nil {
return "", errors.Wrapf(err, "failed to read rbd device dir")
}
for _, idFile := range files {
nameContent, err := ioutil.ReadFile(filepath.Join(sysBusDeviceDir, idFile.Name(), "name"))
if err == nil && imageName == strings.TrimSpace(string(nameContent)) {
// the image for the current rbd device matches, now try to match pool
poolContent, err := ioutil.ReadFile(filepath.Join(sysBusDeviceDir, idFile.Name(), "pool"))
if err == nil && poolName == strings.TrimSpace(string(poolContent)) {
// match current device matches both image name and pool name, return the device
return idFile.Name(), nil
}
}
}
return "", nil
}
// GetIPFromEndpoint return the IP from an endpoint string (192.168.0.1:6789)
func GetIPFromEndpoint(endpoint string) string {
host, _, err := net.SplitHostPort(endpoint)
if err != nil {
logger.Errorf("failed to split ip and port for endpoint %q. %v", endpoint, err)
}
return host
}
// GetPortFromEndpoint return the port from an endpoint string (192.168.0.1:6789)
func GetPortFromEndpoint(endpoint string) int32 {
var port int
_, portString, err := net.SplitHostPort(endpoint)
if err != nil {
logger.Errorf("failed to split host and port for endpoint %q, assuming default Ceph port %q. %v", endpoint, portString, err)
} else {
port, err = strconv.Atoi(portString)
if err != nil {
logger.Errorf("failed to convert %q to integer. %v", portString, err)
}
}
return int32(port)
}