summaryrefslogtreecommitdiff
path: root/sd_daemon
diff options
context:
space:
mode:
authorLuke Shumaker <lukeshu@sbcglobal.net>2015-08-26 12:09:06 -0600
committerLuke Shumaker <lukeshu@sbcglobal.net>2015-08-26 12:09:06 -0600
commit9ec3d8a8761ce3058ead6d189c499ef3a5f8973e (patch)
tree1a8bb847c48a47869d8741387e6fc504594298e6 /sd_daemon
parentf52da1cac583c31a7f0ca5530466dce2bede598e (diff)
clean up
Diffstat (limited to 'sd_daemon')
-rw-r--r--sd_daemon/listen_fds.go51
-rw-r--r--sd_daemon/logger/logger.go23
2 files changed, 74 insertions, 0 deletions
diff --git a/sd_daemon/listen_fds.go b/sd_daemon/listen_fds.go
new file mode 100644
index 0000000..45ef699
--- /dev/null
+++ b/sd_daemon/listen_fds.go
@@ -0,0 +1,51 @@
+// Copyright 2015 CoreOS, Inc.
+// Copyright 2015 Luke Shumaker
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+// Package activation implements primitives for systemd socket activation.
+package sd_daemon
+
+import (
+ "os"
+ "strconv"
+ "syscall"
+)
+
+//#include <systemd/sd-daemon.h>
+import "C"
+
+func ListenFds(unsetEnv bool) []*os.File {
+ if unsetEnv {
+ defer os.Unsetenv("LISTEN_PID")
+ defer os.Unsetenv("LISTEN_FDS")
+ }
+
+ pid, err := strconv.Atoi(os.Getenv("LISTEN_PID"))
+ if err != nil || pid != os.Getpid() {
+ return nil
+ }
+
+ nfds, err := strconv.Atoi(os.Getenv("LISTEN_FDS"))
+ if err != nil || nfds == 0 {
+ return nil
+ }
+
+ files := make([]*os.File, 0, nfds)
+ for fd := C.SD_LISTEN_FDS_START; fd < C.SD_LISTEN_FDS_START+nfds; fd++ {
+ syscall.CloseOnExec(fd)
+ files = append(files, os.NewFile(uintptr(fd), "LISTEN_FD_"+strconv.Itoa(fd)))
+ }
+
+ return files
+}
diff --git a/sd_daemon/logger/logger.go b/sd_daemon/logger/logger.go
new file mode 100644
index 0000000..6c09604
--- /dev/null
+++ b/sd_daemon/logger/logger.go
@@ -0,0 +1,23 @@
+package logger
+
+import (
+ "fmt"
+ "os"
+)
+
+//#include <systemd/sd-daemon.h>
+import "C"
+
+func log(level string, format string, a ...interface{}) {
+ f := level + format + "\n"
+ fmt.Fprintf(os.Stderr, f, a)
+}
+
+/* system is unusable */ func Emerg( format string, a ...interface{}) { log(C.SD_EMERG , format, a); }
+/* action must be taken immediately */ func Alert( format string, a ...interface{}) { log(C.SD_ALERT , format, a); }
+/* critical conditions */ func Crit( format string, a ...interface{}) { log(C.SD_CRIT , format, a); }
+/* error conditions */ func Err( format string, a ...interface{}) { log(C.SD_ERR , format, a); }
+/* warning conditions */ func Warning(format string, a ...interface{}) { log(C.SD_WARNING, format, a); }
+/* normal but significant condition */ func Notice( format string, a ...interface{}) { log(C.SD_NOTICE , format, a); }
+/* informational */ func Info( format string, a ...interface{}) { log(C.SD_INFO , format, a); }
+/* debug-level messages */ func Debug( format string, a ...interface{}) { log(C.SD_DEBUG , format, a); }