summaryrefslogtreecommitdiff
path: root/nslcd_server/func_handlerequest.go.gen
diff options
context:
space:
mode:
authorLuke Shumaker <lukeshu@lukeshu.com>2017-12-18 15:07:24 -0500
committerLuke Shumaker <lukeshu@lukeshu.com>2017-12-18 22:37:34 -0500
commit379e4d7e4d2539f35d559d4b0752531e546238a9 (patch)
tree844ba145ef8bb03824985d3e7a47740b2b5438c2 /nslcd_server/func_handlerequest.go.gen
parent44798efb9ec9a89416658707d952e60e8e5fe01b (diff)
nslcd_{server,systemd}: BREAKING CHANGE: use contexts
Diffstat (limited to 'nslcd_server/func_handlerequest.go.gen')
-rwxr-xr-xnslcd_server/func_handlerequest.go.gen26
1 files changed, 21 insertions, 5 deletions
diff --git a/nslcd_server/func_handlerequest.go.gen b/nslcd_server/func_handlerequest.go.gen
index 00e9663..750a7b0 100755
--- a/nslcd_server/func_handlerequest.go.gen
+++ b/nslcd_server/func_handlerequest.go.gen
@@ -25,12 +25,12 @@ cat <<EOF | gofmt
package nslcd_server
import (
+ "context"
"fmt"
"io"
"os"
"time"
- "golang.org/x/sys/unix"
p "git.lukeshu.com/go/libnslcd/nslcd_proto"
)
@@ -70,8 +70,9 @@ type Conn interface {
SetWriteDeadline(t time.Time) error
}
-// Handle a request to nslcd
-func HandleRequest(backend Backend, limits Limits, conn Conn, cred unix.Ucred) (err error) {
+// Handle a request to nslcd. The caller is responsible for
+// initializing the context with PeerCredKey.
+func HandleRequest(backend Backend, limits Limits, conn Conn, ctx context.Context) (err error) {
defer func() {
if r := recover(); r != nil {
switch r := r.(type) {
@@ -89,6 +90,11 @@ func HandleRequest(backend Backend, limits Limits, conn Conn, cred unix.Ucred) (
if limits.Timeout != 0 {
deadlineAll = now.Add(limits.Timeout)
}
+ if deadline, ok := ctx.Deadline(); ok {
+ if deadlineAll.IsZero() || deadline.Before(deadlineAll) {
+ deadlineAll = deadline
+ }
+ }
if limits.ReadTimeout != 0 {
deadlineRead = now.Add(limits.ReadTimeout)
if !deadlineAll.IsZero() && deadlineAll.Before(deadlineRead) {
@@ -149,6 +155,7 @@ while read -r request; do
;;
esac
)
+
if limits.WriteTimeout != 0 {
deadlineWrite = time.Now().Add(limits.WriteTimeout)
if !deadlineAll.IsZero() && deadlineAll.Before(deadlineWrite) {
@@ -161,9 +168,18 @@ while read -r request; do
return err
}
}
+
+ var cancel context.CancelFunc
+ if deadline, ok := ctx.Deadline(); !ok || (!deadlineWrite.IsZero() && deadline.After(deadlineWrite)) {
+ ctx, cancel = context.WithDeadline(ctx, deadlineWrite)
+ } else {
+ ctx, cancel = context.WithCancel(ctx)
+ }
+ defer cancel()
+
maybePanic(p.Write(out, p.NSLCD_VERSION))
maybePanic(p.Write(out, action))
- ch := backend.${request}(cred, req)
+ ch := backend.${request}(ctx, req)
for result := range ch {
if err == nil {
err = p.Write(out, p.NSLCD_RESULT_BEGIN)
@@ -174,7 +190,7 @@ while read -r request; do
}
maybePanic(err)
maybePanic(p.Write(out, p.NSLCD_RESULT_END))
- return nil
+ return ctx.Err() // probably nil
EOT
done < "$requests"
)