1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
//===----------------------------------------------------------------------===//
//
// This source file is part of the SwiftNIO open source project
//
// Copyright (c) 2019 Apple Inc. and the SwiftNIO project authors
// Licensed under Apache License v2.0
//
// See LICENSE.txt for license information
// See CONTRIBUTORS.txt for the list of SwiftNIO project authors
//
// SPDX-License-Identifier: Apache-2.0
//
//===----------------------------------------------------------------------===//
import NIO
#if os(Linux) || os(FreeBSD)
/// The path to the root CA bundle file.
///
/// May be nil if we could not find the root CA bundle file.
internal let rootCAFilePath: String? = locateRootCAFile()
/// The path to the root CA bundle directory.
///
/// May be nil if we could not find the root CA bundle directory.
internal let rootCADirectoryPath: String? = locateRootCADirectory()
/// This is a list of root CA file search paths. This list contains paths as validated against several distributions.
/// If you are attempting to use SwiftNIO SSL on a platform that is not covered here and certificate validation is
/// failing, please open a pull request that adds the appropriate search path.
private let rootCAFileSearchPaths = [
"/etc/ssl/certs/ca-certificates.crt", // Ubuntu, Debian, Arch, Alpine,
"/etc/pki/tls/certs/ca-bundle.crt", // Fedora
]
/// This is a list of root CA directory search paths.
///
/// This list contains paths as validated against several distributions. If you are aware of a CA bundle on a specific distribution
/// that is not present here, please open a pull request that adds the appropriate search path.
/// Some distributions do not ship CA directories: as such, it is not a problem if a distribution that is present in rootCAFileSearchPaths
/// is not present in this list.
private let rootCADirectorySearchPaths = [
"/etc/ssl/certs", // Ubuntu, Debian, Arch, Alpine
]
private func locateRootCAFile() -> String? {
// We need to find the root CA file. We have a list of search paths: let's use them.
return rootCAFileSearchPaths.first(where: { FileSystemObject.pathType(path: $0) == .file })
}
private func locateRootCADirectory() -> String? {
return rootCADirectorySearchPaths.first(where: { FileSystemObject.pathType(path: $0) == .directory })
}
#endif
|