Merge pull request #370 from ipfs/fix/svc/init/lock
cmd/svc/lock: check config dir and file existence
This commit is contained in:
commit
95ae1746b7
|
@ -4,6 +4,7 @@ package main
|
|||
import (
|
||||
"fmt"
|
||||
"io"
|
||||
"os"
|
||||
"path"
|
||||
|
||||
fslock "github.com/ipfs/go-fs-lock"
|
||||
|
@ -24,6 +25,11 @@ func (l *lock) lock() error {
|
|||
if l.lockCloser != nil {
|
||||
return fmt.Errorf("cannot acquire lock twice")
|
||||
}
|
||||
|
||||
if err := l.checkConfigExists(); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
// set the lock file within this function
|
||||
logger.Debug("checking lock")
|
||||
lk, err := fslock.Lock(l.path, lockFileName)
|
||||
|
@ -56,3 +62,15 @@ func (l *lock) tryUnlock() error {
|
|||
l.lockCloser = nil
|
||||
return nil
|
||||
}
|
||||
|
||||
func (l *lock) checkConfigExists() error {
|
||||
if _, err := os.Stat(l.path); os.IsNotExist(err) {
|
||||
logger.Error("ipfs-cluster-service config hasn't been initialized.\nPlease run ipfs-cluster-service init")
|
||||
return err
|
||||
}
|
||||
if _, err := os.Stat(fmt.Sprintf("%s/%s", l.path, "service.json")); os.IsNotExist(err) {
|
||||
logger.Error("ipfs-cluster-service config hasn't been initialized.\nPlease run ipfs-cluster-service init")
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user