mirror of
https://github.com/aptly-dev/aptly.git
synced 2026-04-20 19:38:39 +00:00
systemd has a feature called socket activation where initially systemd manages and listens on ports/uds and only invokes a service when traffic appears. to then hand over the involved sockets, systemd will pass the relevant FDs into the invoked process and defines them in the environment. use coreos/go-systemd to grab the active listeners passed by systemd and use them to serve the api routes. only one listener may be specified right now as we also only support one -listen argument for the binary. this allows admins to craft a systemd socket and service file for aptly where systemd manages the socket, its permission and its live time, and lazy start aptly when needed.
38 lines
1.2 KiB
Go
38 lines
1.2 KiB
Go
// Copyright 2015 CoreOS, Inc.
|
|
//
|
|
// 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
|
|
|
|
import (
|
|
"net"
|
|
)
|
|
|
|
// PacketConns returns a slice containing a net.PacketConn for each matching socket type
|
|
// passed to this process.
|
|
//
|
|
// The order of the file descriptors is preserved in the returned slice.
|
|
// Nil values are used to fill any gaps. For example if systemd were to return file descriptors
|
|
// corresponding with "udp, tcp, udp", then the slice would contain {net.PacketConn, nil, net.PacketConn}
|
|
func PacketConns(unsetEnv bool) ([]net.PacketConn, error) {
|
|
files := Files(unsetEnv)
|
|
conns := make([]net.PacketConn, len(files))
|
|
|
|
for i, f := range files {
|
|
if pc, err := net.FilePacketConn(f); err == nil {
|
|
conns[i] = pc
|
|
}
|
|
}
|
|
return conns, nil
|
|
}
|