2019-02-14 17:35:18 +03:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/ceph/go-ceph/rados"
|
|
|
|
"log"
|
2019-02-15 20:04:32 +03:00
|
|
|
"os"
|
2019-02-14 17:35:18 +03:00
|
|
|
)
|
|
|
|
|
2019-02-19 10:16:11 +03:00
|
|
|
func connectioninit(params Params) *Cephconnection {
|
2019-02-15 20:04:32 +03:00
|
|
|
cephconn := &Cephconnection{}
|
2019-02-14 17:35:18 +03:00
|
|
|
var err error
|
|
|
|
if _, err := os.Stat(params.config); os.IsNotExist(err) {
|
|
|
|
log.Fatalf("Congif file not exists. Error: %v\n", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := os.Stat(params.keyring); os.IsNotExist(err) {
|
|
|
|
log.Fatalf("Keyring file not exists. Error: %v\n", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
cephconn.conn, err = rados.NewConnWithClusterAndUser(params.cluster, params.user)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("Can't create connection with cluster:%v and user:%v. Error: %v\n", params.cluster, params.user, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = cephconn.conn.ReadConfigFile(params.config); err != nil {
|
2019-02-19 18:24:34 +03:00
|
|
|
log.Fatalf("Can't read config file. Error: %v\n", err)
|
2019-02-14 17:35:18 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
if err = cephconn.conn.SetConfigOption("keyring", params.keyring); err != nil {
|
2019-02-19 18:24:34 +03:00
|
|
|
log.Fatalf("Can't set config option. Error: %v\n", err)
|
2019-02-14 17:35:18 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
if err = cephconn.conn.Connect(); err != nil {
|
|
|
|
log.Fatalf("Failed to connect cluster. Error: %v\n", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
cephconn.ioctx, err = cephconn.conn.OpenIOContext(params.pool)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("Can't open pool %v. Error: %v\n", params.pool, err)
|
|
|
|
}
|
|
|
|
return cephconn
|
2019-02-15 20:04:32 +03:00
|
|
|
}
|