mirror of
https://github.com/XTLS/Xray-core.git
synced 2024-11-23 21:56:06 +03:00
079d0bd8a9
* Refactor log * Add new log methods * Fix logger test * Change all logging code * Clean up pathObj * Rebase to latest main * Remove invoking method name after the dot
40 lines
914 B
Go
40 lines
914 B
Go
//go:build !windows
|
|
// +build !windows
|
|
|
|
package internet
|
|
|
|
import (
|
|
"context"
|
|
"os"
|
|
|
|
"github.com/xtls/xray-core/common/errors"
|
|
"golang.org/x/sys/unix"
|
|
)
|
|
|
|
// Acquire lock
|
|
func (fl *FileLocker) Acquire() error {
|
|
f, err := os.Create(fl.path)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if err := unix.Flock(int(f.Fd()), unix.LOCK_EX); err != nil {
|
|
f.Close()
|
|
return errors.New("failed to lock file: ", fl.path).Base(err)
|
|
}
|
|
fl.file = f
|
|
return nil
|
|
}
|
|
|
|
// Release lock
|
|
func (fl *FileLocker) Release() {
|
|
if err := unix.Flock(int(fl.file.Fd()), unix.LOCK_UN); err != nil {
|
|
errors.LogInfoInner(context.Background(), err, "failed to unlock file: ", fl.path)
|
|
}
|
|
if err := fl.file.Close(); err != nil {
|
|
errors.LogInfoInner(context.Background(), err, "failed to close file: ", fl.path)
|
|
}
|
|
if err := os.Remove(fl.path); err != nil {
|
|
errors.LogInfoInner(context.Background(), err, "failed to remove file: ", fl.path)
|
|
}
|
|
}
|