X-Git-Url: http://www.git.cypherpunks.ru/?a=blobdiff_plain;f=src%2Flockdir.go;h=a756381bee0f5d353d602112c75080cef0704694;hb=7696544068749db54f07c21cd658557905302fe4;hp=38144eea6f5b8d73164dfc05388dd8841390446b;hpb=3a710c60770ddbc553ea0de627aef6153e7088c7;p=nncp.git diff --git a/src/lockdir.go b/src/lockdir.go index 38144ee..a756381 100644 --- a/src/lockdir.go +++ b/src/lockdir.go @@ -1,6 +1,6 @@ /* NNCP -- Node to Node copy, utilities for store-and-forward data exchange -Copyright (C) 2016-2020 Sergey Matveev +Copyright (C) 2016-2022 Sergey Matveev This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -25,7 +25,9 @@ import ( ) func (ctx *Ctx) LockDir(nodeId *NodeId, lockCtx string) (*os.File, error) { - ctx.ensureRxDir(nodeId) + if err := ctx.ensureRxDir(nodeId); err != nil { + return nil, err + } lockPath := filepath.Join(ctx.Spool, nodeId.String(), lockCtx) + ".lock" dirLock, err := os.OpenFile( lockPath, @@ -33,13 +35,17 @@ func (ctx *Ctx) LockDir(nodeId *NodeId, lockCtx string) (*os.File, error) { os.FileMode(0666), ) if err != nil { - ctx.LogE("lockdir", SDS{"path": lockPath}, err, "") + ctx.LogE("lockdir-open", LEs{{"Path", lockPath}}, err, func(les LEs) string { + return "Locking directory: opening " + lockPath + }) return nil, err } err = unix.Flock(int(dirLock.Fd()), unix.LOCK_EX|unix.LOCK_NB) if err != nil { - ctx.LogE("lockdir", SDS{"path": lockPath}, err, "") - dirLock.Close() // #nosec G104 + ctx.LogE("lockdir-flock", LEs{{"Path", lockPath}}, err, func(les LEs) string { + return "Locking directory: locking " + lockPath + }) + dirLock.Close() return nil, err } return dirLock, nil @@ -47,7 +53,7 @@ func (ctx *Ctx) LockDir(nodeId *NodeId, lockCtx string) (*os.File, error) { func (ctx *Ctx) UnlockDir(fd *os.File) { if fd != nil { - unix.Flock(int(fd.Fd()), unix.LOCK_UN) // #nosec G104 - fd.Close() // #nosec G104 + unix.Flock(int(fd.Fd()), unix.LOCK_UN) + fd.Close() } }