|
Packit |
63bb0d |
// Copyright 2015 CoreOS, Inc.
|
|
Packit |
63bb0d |
//
|
|
Packit |
63bb0d |
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
Packit |
63bb0d |
// you may not use this file except in compliance with the License.
|
|
Packit |
63bb0d |
// You may obtain a copy of the License at
|
|
Packit |
63bb0d |
//
|
|
Packit |
63bb0d |
// http://www.apache.org/licenses/LICENSE-2.0
|
|
Packit |
63bb0d |
//
|
|
Packit |
63bb0d |
// Unless required by applicable law or agreed to in writing, software
|
|
Packit |
63bb0d |
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
Packit |
63bb0d |
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
Packit |
63bb0d |
// See the License for the specific language governing permissions and
|
|
Packit |
63bb0d |
// limitations under the License.
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
package activation
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
import (
|
|
Packit |
63bb0d |
"crypto/tls"
|
|
Packit |
63bb0d |
"net"
|
|
Packit |
63bb0d |
)
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
// Listeners returns a slice containing a net.Listener for each matching socket type
|
|
Packit |
63bb0d |
// passed to this process.
|
|
Packit |
63bb0d |
//
|
|
Packit |
63bb0d |
// The order of the file descriptors is preserved in the returned slice.
|
|
Packit |
63bb0d |
// Nil values are used to fill any gaps. For example if systemd were to return file descriptors
|
|
Packit |
63bb0d |
// corresponding with "udp, tcp, tcp", then the slice would contain {nil, net.Listener, net.Listener}
|
|
Packit |
63bb0d |
func Listeners() ([]net.Listener, error) {
|
|
Packit |
63bb0d |
files := Files(true)
|
|
Packit |
63bb0d |
listeners := make([]net.Listener, len(files))
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
for i, f := range files {
|
|
Packit |
63bb0d |
if pc, err := net.FileListener(f); err == nil {
|
|
Packit |
63bb0d |
listeners[i] = pc
|
|
Packit |
63bb0d |
f.Close()
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
return listeners, nil
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
// ListenersWithNames maps a listener name to a set of net.Listener instances.
|
|
Packit |
63bb0d |
func ListenersWithNames() (map[string][]net.Listener, error) {
|
|
Packit |
63bb0d |
files := Files(true)
|
|
Packit |
63bb0d |
listeners := map[string][]net.Listener{}
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
for _, f := range files {
|
|
Packit |
63bb0d |
if pc, err := net.FileListener(f); err == nil {
|
|
Packit |
63bb0d |
current, ok := listeners[f.Name()]
|
|
Packit |
63bb0d |
if !ok {
|
|
Packit |
63bb0d |
listeners[f.Name()] = []net.Listener{pc}
|
|
Packit |
63bb0d |
} else {
|
|
Packit |
63bb0d |
listeners[f.Name()] = append(current, pc)
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
f.Close()
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
return listeners, nil
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
// TLSListeners returns a slice containing a net.listener for each matching TCP socket type
|
|
Packit |
63bb0d |
// passed to this process.
|
|
Packit |
63bb0d |
// It uses default Listeners func and forces TCP sockets handlers to use TLS based on tlsConfig.
|
|
Packit |
63bb0d |
func TLSListeners(tlsConfig *tls.Config) ([]net.Listener, error) {
|
|
Packit |
63bb0d |
listeners, err := Listeners()
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
if listeners == nil || err != nil {
|
|
Packit |
63bb0d |
return nil, err
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
if tlsConfig != nil {
|
|
Packit |
63bb0d |
for i, l := range listeners {
|
|
Packit |
63bb0d |
// Activate TLS only for TCP sockets
|
|
Packit |
63bb0d |
if l.Addr().Network() == "tcp" {
|
|
Packit |
63bb0d |
listeners[i] = tls.NewListener(l, tlsConfig)
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
return listeners, err
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
// TLSListenersWithNames maps a listener name to a net.Listener with
|
|
Packit |
63bb0d |
// the associated TLS configuration.
|
|
Packit |
63bb0d |
func TLSListenersWithNames(tlsConfig *tls.Config) (map[string][]net.Listener, error) {
|
|
Packit |
63bb0d |
listeners, err := ListenersWithNames()
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
if listeners == nil || err != nil {
|
|
Packit |
63bb0d |
return nil, err
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
if tlsConfig != nil {
|
|
Packit |
63bb0d |
for _, ll := range listeners {
|
|
Packit |
63bb0d |
// Activate TLS only for TCP sockets
|
|
Packit |
63bb0d |
for i, l := range ll {
|
|
Packit |
63bb0d |
if l.Addr().Network() == "tcp" {
|
|
Packit |
63bb0d |
ll[i] = tls.NewListener(l, tlsConfig)
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
}
|
|
Packit |
63bb0d |
|
|
Packit |
63bb0d |
return listeners, err
|
|
Packit |
63bb0d |
}
|